搜索
首页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

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。