热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

php二维数组以某一键名进行分组相加

如题,如果是从数据库里取数据的时候大可以使用如下SQLSELECTSUM(t_value),t_idFROMt_tableGROUPBYt_id但是如果是在php程序中处

如题,如果是从数据库里取数据的时候大可以使用如下SQL

SELECT SUM(t_value),t_id FROM t_table GROUP BY t_id

但是如果是在php程序中处理类似的问题就稍微麻烦点了,这里给个函数就是处理类似的问题,实例代码如下:

  1. /* 函数功能:对二维数组以某一键名进行分组相加,返回新的二维数组  
  2.  * 参数说明:$arr-源数组;$new_arr-相加后得到的新数组;$target_key-要分组的键名  
  3.  */ 
  4. function add_array($arr, &$new_arr$target_key) {  
  5.     $num = count($new_arr); //计算新数组的大小,新数组也是二维的,这里计算的是第一维  
  6.     for ($i = 0; $i < $num$i++) {  
  7.         //循环新数组  
  8.         //if块主要判断当前分组的键名是否已经存在于新数组中,避免重复  
  9.         //由于该函数是被循环调用的,而新数组可能有多于1个的元素,所以必须对新数组中的每一个元素都进行比较,  
  10.         //新数组的元素是一个一维数组,$i动态的比较新的二维数组中的分组键名  
  11.         if ($arr[$target_key] != $new_arr[$i][$target_key]) {//判断新数组中的分组键名是否跟当前源数组中的分组键名相等  
  12.             $cmp_num++; //如果不相等,比较次数自增1  
  13.         } else {//如果相等,说明当前分组键名已经存在  
  14.             $tar_exist = true; //设置存在标识为true  
  15.             $tar_key = $i//返回当前分组键名在新数组中的数字索引  
  16.             break//跳出循环  
  17.         }  
  18.     }  
  19.     //如果比较次数跟新数组大小一样,说明当前分组键名不在新数组中,设置存在标识为false  
  20.     if ($cmp_num == $num)  
  21.         $tar_exist = false;  
  22.     if ($tar_exist) {//如果分组键名已经存在,对该分组的数组元素进行相加  
  23.         foreach ($arr as $key => $value) {  
  24.             if ($key != $target_key) {//分组键名对应的元素值不相加  
  25.                 $new_arr[$tar_key][$key]+=$value//其余的元素值进行相加  
  26.             }  
  27.         }  
  28.     } else {  
  29.         //如果分组键名不存在  
  30.         //设置新的分组键名,并对该分组的数组元素进行相加  
  31.         //新数组的第一维使用$num参数来分辨当前分组的秩序  
  32.         //由于$num实际上就是新数组中,按键名分组的个数,并且是从0开始,所以新的分组在新数组中的索引直接用$num即可,  
  33.         //而不须要$num+1  
  34.         $new_arr[$num][$target_key] = $arr[$target_key];  
  35.         foreach ($arr as $key => $value) {  
  36.             if ($key != $target_key) {//分组键名对应的元素值不相加  
  37.                 $new_arr[$num][$key]+=$value//其余的元素值进行相加  
  38.             }  
  39.         }  
  40.     }  
  41. }  
  42. $arr = array(  
  43.     array(&#39;group_id&#39; => 13, &#39;team_price&#39; => 88.00, &#39;satopay_price&#39; => 85.00, &#39;team_id&#39; => 348, &#39;origin&#39; => 440, &#39;gain&#39; => 14.45, &#39;quantity&#39; => 5),  
  44.     array(&#39;group_id&#39; => 13, &#39;team_price&#39; => 12.00, &#39;satopay_price&#39; => 11.00, &#39;team_id&#39; => 344, &#39;origin&#39; => 36, &#39;gain&#39; => 2.76, &#39;quantity&#39; => 3),  
  45.     array(&#39;group_id&#39; => 14, &#39;team_price&#39; => 4.99, &#39;satopay_price&#39; => 4.60, &#39;team_id&#39; => 335, &#39;origin&#39; => 4.99, &#39;gain&#39; => 0.31915, &#39;quantity&#39; => 1),  
  46.     array(&#39;group_id&#39; => 14, &#39;team_price&#39; => 12.00, &#39;satopay_price&#39; => 11.00, &#39;team_id&#39; => 344, &#39;origin&#39; => 24, &#39;gain&#39; => 1.84, &#39;quantity&#39; => 2),  
  47.     array(&#39;group_id&#39; => 15, &#39;team_price&#39; => 13.00, &#39;satopay_price&#39; => 11.00, &#39;team_id&#39; => 344, &#39;origin&#39; => 24, &#39;gain&#39; => 1.84, &#39;quantity&#39; => 2),  
  48. );  
  49. $new_arr = array();  
  50. foreach ($arr as $key => $value) {  
  51.     add_array($value, &$new_arr&#39;group_id&#39;); //这里我们按group_id进行分组相加  
  52. }  
  53. var_dump($new_arr); 

推荐阅读
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了《中秋夜作》的翻译及原文赏析,以及诗人当代钱钟书的背景和特点。通过对诗歌的解读,揭示了其中蕴含的情感和意境。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • 本文描述了作者第一次参加比赛的经历和感受。作者是小学六年级时参加比赛的唯一选手,感到有些紧张。在比赛期间,作者与学长学姐一起用餐,在比赛题目中遇到了一些困难,但最终成功解决。作者还尝试了一款游戏,在回程的路上感到晕车。最终,作者以110分的成绩取得了省一会的资格,并坚定了继续学习的决心。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 大连微软技术社区举办《.net core始于足下》活动,获得微软赛百味和易迪斯的赞助
    九月十五日,大连微软技术社区举办了《.net core始于足下》活动,共有51人报名参加,实际到场人数为43人,还有一位专程从北京赶来的同学。活动得到了微软赛百味和易迪斯的赞助,场地也由易迪斯提供。活动中大家积极交流,取得了非常成功的效果。 ... [详细]
  • 给定一个二叉树,要求随机选择树上的一个节点。解法:遍历树的过程中,随机选择一个节点即可。具体做法参看:从输入 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
author-avatar
天涯使者2602921991
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有