搜尋
首頁php教程php手册php 用键名分组相加的二维数组实例函数

php 用键名分组相加的二维数组实例函数

Jun 06, 2016 pm 07:52 PM
php函數分組實例陣列相加進入鍵名

欢迎进入Linux社区论坛,与200万技术人员互动交流 >>进入 本文介绍一篇关于php 二维数组以某一键名进行分组相加的实例程序,如果是从数据库里取数据的时候大可以SELECT SUM(t_value),t_id FROM t_table GROUP BY t_id,但是如果是在php程序中处理类似的问

欢迎进入Linux社区论坛,与200万技术人员互动交流 >>进入

  本文介绍一篇关于php 二维数组以某一键名进行分组相加的实例程序,如果是从数据库里取数据的时候大可以SELECT SUM(t_value),t_id FROM t_table GROUP BY t_id,但是如果是在php程序中处理类似的问题就稍微不太好办了,这里给个函数就是处理类似的问题

  代码如下:

  [php] view plaincopy

  

  /* 函数功能:对二维数组以某一键名进行分组相加,返回新的二维数组

  * 参数说明:$arr-源数组;$new_arr-相加后得到的新数组;$target_key-要分组的键名

  */  unity3d下载http://www.unitymanual.com

  function add_array($arr, &$new_arr, $target_key) {

  $num = count($new_arr); //计算新数组的大小,新数组也是二维的,这里计算的是第一维

  for ($i = 0; $i

  //循环新数组 (PS:^_^不错的php开发交流群:304224365,验证:csl,谢谢!)

  //if块主要判断当前分组的键名是否已经存在于新数组中,避免重复

  //由于该函数是被循环调用的,而新数组可能有多于1个的元素,所以必须对新数组中的每一个元素都进行比较,

  //新数组的元素是一个一维数组,$i动态的比较新的二维数组中的分组键名

  if ($arr[$target_key] != $new_arr[$i][$target_key]) {//判断新数组中的分组键名是否跟当前源数组中的分组键名相等

  $cmp_num++; //如果不相等,比较次数自增1

  } else {//如果相等,说明当前分组键名已经存在

  $tar_exist = true; //设置存在标识为true

  $tar_key = $i; //返回当前分组键名在新数组中的数字索引

  break; //跳出循环

  }

  }

  //如果比较次数跟新数组大小一样,说明当前分组键名不在新数组中,设置存在标识为false

  if ($cmp_num == $num)

  $tar_exist = false;

  if ($tar_exist) {//如果分组键名已经存在,对该分组的数组元素进行相加

  foreach ($arr as $key => $value) {

  if ($key != $target_key) {//分组键名对应的元素值不相加

  $new_arr[$tar_key][$key]+=$value; //其余的元素值进行相加

  }

  }

  } else {

  //如果分组键名不存在

  //设置新的分组键名,并对该分组的数组元素进行相加

  //新数组的第一维使用$num参数来分辨当前分组的秩序

  //由于$num实际上就是新数组中,按键名分组的个数,并且是从0开始,所以新的分组在新数组中的索引直接用$num即可,

  //而不须要$num+1

  $new_arr[$num][$target_key] = $arr[$target_key];

  foreach ($arr as $key => $value) {

  if ($key != $target_key) {//分组键名对应的元素值不相加

  $new_arr[$num][$key]+=$value; //其余的元素值进行相加

  }

  }

  }

  }

  $arr = array(

  array('group_id' => 13, 'team_price' => 88.00, 'satopay_price' => 85.00, 'team_id' => 348, 'origin' => 440, 'gain' => 14.45, 'quantity' => 5),

  array('group_id' => 13, 'team_price' => 12.00, 'satopay_price' => 11.00, 'team_id' => 344, 'origin' => 36, 'gain' => 2.76, 'quantity' => 3),

  array('group_id' => 14, 'team_price' => 4.99, 'satopay_price' => 4.60, 'team_id' => 335, 'origin' => 4.99, 'gain' => 0.31915, 'quantity' => 1),

  array('group_id' => 14, 'team_price' => 12.00, 'satopay_price' => 11.00, 'team_id' => 344, 'origin' => 24, 'gain' => 1.84, 'quantity' => 2),

  array('group_id' => 15, 'team_price' => 13.00, 'satopay_price' => 11.00, 'team_id' => 344, 'origin' => 24, 'gain' => 1.84, 'quantity' => 2),

  );

  $new_arr = array();

  foreach ($arr as $key => $value) {

  add_array($value, &$new_arr, 'group_id'); //这里我们按group_id进行分组相加

  }

  var_dump($new_arr);

  以上是本文关于 php 用键名分组相加的二维数组实例函数,希望本文对广大php开发者有所帮助,感谢阅读本文。

php 用键名分组相加的二维数组实例函数

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)