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


Posted in PHP onNovember 06, 2013

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

<?php 
/* 函数功能:对二维数组以某一键名进行分组相加,返回新的二维数组 
 * 参数说明:$arr-源数组;$new_arr-相加后得到的新数组;$target_key-要分组的键名 
 */
function add_array($arr, &$new_arr, $target_key) { 
    $num = count($new_arr); //计算新数组的大小,新数组也是二维的,这里计算的是第一维 
    for ($i = 0; $i < $num; $i++) { 
        //循环新数组 
        //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 相关文章推荐
用DBSQL类加快开发MySQL数据库程序的速度
Oct 09 PHP
Smarty+QUICKFORM小小演示
Feb 25 PHP
php防盗链的常用方法小结
Jul 02 PHP
注册页面之前先验证用户名是否存在的php代码
Jul 14 PHP
php中$_POST与php://input的区别实例分析
Jan 07 PHP
PHP使用适合阅读的格式显示文件大小的方法
Mar 05 PHP
php生成验证码,缩略图及水印图的类分享
Apr 07 PHP
PHP树-不需要递归的实现方法
Jun 21 PHP
php文件类型MIME对照表(比较全)
Oct 07 PHP
Laravel 5.5 的自定义验证对象/类示例代码详解
Aug 29 PHP
PHP 使用二进制保存用户状态的实例
Jan 29 PHP
thinkPHP5框架实现基于ajax的分页功能示例
Jun 12 PHP
php不用正则验证真假身份证
Nov 06 #PHP
php 中文字符串首字母的获取函数分享
Nov 04 #PHP
PHP图片上传代码
Nov 04 #PHP
PHP CURL获取cookies模拟登录的方法
Nov 04 #PHP
php Session存储到Redis的方法
Nov 04 #PHP
在PHP中使用redis
Nov 04 #PHP
6种php上传图片重命名的方法实例
Nov 04 #PHP
You might like
基于jQuery实现下拉收缩(展开与折叠)特效
2012/12/25 Javascript
Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法总结
2013/11/14 Javascript
Nodejs中调用系统命令、Shell脚本和Python脚本的方法和实例
2015/01/01 NodeJs
XML、HTML、CSS与JS的区别整理
2016/02/18 Javascript
JS上传图片预览插件制作(兼容到IE6)
2016/08/07 Javascript
jQuery制作圣诞主题页面 更像是爱情影集
2016/08/10 Javascript
总结Node.js中的一些错误类型
2016/08/15 Javascript
Node.js中process模块常用的属性和方法
2016/12/13 Javascript
Javascript(es2016) import和require用法和区别详解
2017/08/11 Javascript
深入理解ES7的async/await的用法
2017/09/09 Javascript
使用vue2实现带地区编号和名称的省市县三级联动效果
2018/11/05 Javascript
微信小程序HTTP接口请求封装代码实例
2019/09/05 Javascript
JavaScript中的null和undefined用法解析
2019/09/30 Javascript
js实现随机点名程序
2020/09/17 Javascript
实例讲解JavaScript 计时事件
2020/07/04 Javascript
Vue toFixed保留两位小数的3种方式
2020/10/23 Javascript
微信小程序抽奖组件的使用步骤
2021/01/11 Javascript
在Python中使用全局日志时需要注意的问题
2015/05/06 Python
Python中使用strip()方法删除字符串中空格的教程
2015/05/20 Python
python检查URL是否正常访问的小技巧
2017/02/25 Python
python3.4下django集成使用xadmin后台的方法
2017/08/15 Python
python用户管理系统的实例讲解
2017/12/23 Python
Python2和Python3.6环境解决共存问题
2018/11/09 Python
python远程调用rpc模块xmlrpclib的方法
2019/01/11 Python
Python模拟伯努利试验和二项分布代码实例
2020/05/27 Python
财务会计专业个人求职信范本
2014/01/08 职场文书
本科毕业生自荐信
2014/06/02 职场文书
关于保护环境的标语
2014/06/09 职场文书
基层党员干部四风问题整改方向和措施
2014/09/25 职场文书
保安2014年终工作总结
2014/12/06 职场文书
给老婆的检讨书1000字
2015/01/01 职场文书
安娜卡列尼娜观后感
2015/06/11 职场文书
班主任经验交流心得体会
2015/11/02 职场文书
Django一小时写出账号密码管理系统
2021/04/29 Python
MySQL 如何限制一张表的记录数
2021/09/14 MySQL
详细聊聊Oracle表碎片对性能有多大的影响
2022/03/19 Oracle