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实现像JSP,ASP里Application那样的全局变量
Jan 12 PHP
Wordpress php 分页代码
Oct 21 PHP
表格展示无限级分类(PHP版)
Aug 21 PHP
PHP分多步骤填写发布信息的简单方法实例代码
Sep 23 PHP
解析zend studio中直接导入svn中的项目的方法步骤
Jun 21 PHP
ThinkPHP提交表单时默认自动转义的解决方法
Nov 25 PHP
php将access数据库转换到mysql数据库的方法
Dec 24 PHP
php获取当月最后一天函数分享
Feb 02 PHP
PHP之浮点数计算比较以及取整数不准确的解决办法
Jul 29 PHP
php可变长参数处理函数详解
Feb 22 PHP
详细解读php的命名空间(二)
Feb 21 PHP
Yii2框架中一些折磨人的坑
Dec 15 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中拷贝构造函数、赋值运算符重载
2012/07/25 PHP
迅速确定php多维数组的深度的方法
2014/01/07 PHP
php计算程序运行时间的简单例子分享
2014/05/10 PHP
总结PHP代码规范、流程规范、git规范
2018/06/18 PHP
Laravel框架路由管理简单示例
2019/05/07 PHP
Javascript 中的类和闭包
2010/01/08 Javascript
jQuery不间断滚动效果(模拟百度新闻支持文字/图片/垂直滚动)
2013/02/05 Javascript
extjs两个tbar问题探讨
2013/08/08 Javascript
jquery解析xml字符串简单示例
2014/04/11 Javascript
JavaScript 面向对象与原型
2015/04/10 Javascript
JS实现漂亮的窗口拖拽效果(可改变大小、最大化、最小化、关闭)
2015/10/10 Javascript
javascript随机抽取0-100之间不重复的10个数
2016/02/25 Javascript
浅谈js函数三种定义方式 &amp; 四种调用方式 &amp; 调用顺序
2017/02/19 Javascript
Node.js微信 access_token ( jsapi_ticket ) 存取与刷新的示例
2017/09/30 Javascript
详解webpack babel的配置
2018/01/09 Javascript
vuejs中监听窗口关闭和窗口刷新事件的方法
2018/09/21 Javascript
javascript数组元素删除方法delete和splice解析
2019/12/09 Javascript
原生js实现日期选择插件
2020/05/21 Javascript
用Python编写脚本使IE实现代理上网的教程
2015/04/23 Python
Python实现二维有序数组查找的方法
2016/04/27 Python
Python中扩展包的安装方法详解
2017/06/14 Python
Python实现的朴素贝叶斯算法经典示例【测试可用】
2018/06/13 Python
Python代码打开本地.mp4格式文件的方法
2019/01/03 Python
对python 自定义协议的方法详解
2019/02/13 Python
解决Python正则表达式匹配反斜杠''\''问题
2019/07/17 Python
django 信号调度机制详解
2019/07/19 Python
pygame实现俄罗斯方块游戏(AI篇1)
2019/10/29 Python
Python 列表反转显示的四种方法
2020/11/16 Python
mui几种页面跳转方式对比总结概括
2017/08/18 HTML / CSS
中医专业应届生求职信
2013/11/17 职场文书
工作时间上网检讨书
2014/02/03 职场文书
应届毕业生自荐信例文
2014/02/26 职场文书
感恩节活动策划方案
2014/05/16 职场文书
法人授权委托书范本
2014/09/17 职场文书
工作推荐信模板
2015/03/25 职场文书
2015年语言文字工作总结
2015/07/23 职场文书