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 相关文章推荐
PHP生成带有雪花背景的验证码
Oct 09 PHP
DISCUZ 分页代码
Jan 02 PHP
sphinx增量索引的一个问题
Jun 14 PHP
PHP中读写文件实现代码
Oct 20 PHP
基于ubuntu下nginx+php+mysql安装配置的具体操作步骤
Apr 28 PHP
php简单浏览目录内容的实现代码
Jun 07 PHP
深入解析PHP中逗号与点号的区别
Aug 05 PHP
在Mac OS的PHP环境下安装配置MemCache的全过程解析
Feb 15 PHP
php微信高级接口群发 多客服
Jun 23 PHP
php实现博客,论坛图片防盗链的方法
Oct 15 PHP
PHP利用二叉堆实现TopK-算法的方法详解
Apr 24 PHP
phpstorm 配置xdebug的示例代码
Mar 31 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
PHP PDO函数库详解
2010/04/27 PHP
php替换超长文本中的特殊字符的函数代码
2012/05/22 PHP
PHP基础陷阱题(变量赋值)
2012/09/12 PHP
PHP中$_SERVER的详细参数与说明介绍
2013/10/26 PHP
PHP把MSSQL数据导入到MYSQL的方法
2014/12/27 PHP
PHP设计模式之单例模式原理与实现方法分析
2018/04/25 PHP
php实现微信原生支付(扫码支付)功能
2018/05/30 PHP
jQuery实现网站添加高亮突出显示效果的方法
2015/06/26 Javascript
vue项目优化之通过keep-alive数据缓存的方法
2017/12/11 Javascript
微信小程序 自定义复选框实现代码实例
2019/09/04 Javascript
微信小程序定义和调用全局变量globalData的实现
2019/11/01 Javascript
如何正确解决VuePress本地访问出现资源报错404的问题
2020/12/03 Vue.js
浅析Python 读取图像文件的性能对比
2019/03/07 Python
Python 把序列转换为元组的函数tuple方法
2019/06/27 Python
Django model select的多种用法详解
2019/07/16 Python
Python 调用 Outlook 发送邮件过程解析
2019/08/08 Python
Python下应用opencv 实现人脸检测功能
2019/10/24 Python
Python3 读取Word文件方式
2020/02/13 Python
python输入一个水仙花数(三位数) 输出百位十位个位实例
2020/05/03 Python
Python实现清理微信僵尸粉功能示例【基于itchat模块】
2020/05/29 Python
Python分类测试代码实例汇总
2020/07/23 Python
如何利用input事件来监听移动端的输入
2016/04/15 HTML / CSS
意大利奢侈品购物网站:Giglio
2018/01/05 全球购物
印度排名第一的蛋糕、鲜花和礼品送货:Winni
2019/08/02 全球购物
国外的一些J2EE面试题一
2012/10/13 面试题
师范生自我鉴定范文
2013/10/05 职场文书
安全教育心得体会
2013/12/29 职场文书
转党组织关系介绍信
2014/01/08 职场文书
学生期末评语大全
2014/04/30 职场文书
办公室主任竞聘演讲稿
2014/05/15 职场文书
计算机网络专业自荐信
2014/07/04 职场文书
2014年教研组工作总结
2014/11/26 职场文书
社区五一劳动节活动总结
2015/02/09 职场文书
2015年幼儿园国庆节活动总结
2015/07/30 职场文书
《观潮》教学反思
2016/02/17 职场文书
原来闭幕词是这样写的呀!
2019/07/01 职场文书