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+MSSQL分页的例子
Oct 09 PHP
PHP_MySQL教程-第一天
Mar 18 PHP
关于php操作mysql执行数据库查询的一些常用操作汇总
Jun 24 PHP
在SAE上搭建最新wordpress的方法
Dec 21 PHP
ThinkPHP 404页面的设置方法
Jan 14 PHP
php实现将字符串按照指定距离进行分割的方法
Mar 14 PHP
php比较相似字符串的方法
Jun 05 PHP
php实现异步数据调用的方法
Dec 24 PHP
Zend Framework教程之配置文件application.ini解析
Mar 10 PHP
PHP目录操作实例总结
Sep 27 PHP
thinkphp ajaxfileupload实现异步上传图片的示例
Aug 28 PHP
redis+php实现微博(一)注册与登录功能详解
Sep 23 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提取字符串中的手机号正则表达式怎么写
2017/07/17 PHP
php实现姓名根据首字母排序的类与方法(实例代码)
2018/05/16 PHP
PHP观察者模式定义与用法实例分析
2019/03/22 PHP
网页源代码保护(禁止右键、复制、另存为、查看源文件)
2012/05/23 Javascript
js统计页面的来访次数实现代码
2014/05/09 Javascript
js鼠标点击图片切换效果代码分享
2015/08/26 Javascript
JavaScript+html5 canvas绘制渐变区域完整实例
2016/01/26 Javascript
javascript获取网页各种高宽及位置的方法总结
2016/07/27 Javascript
JavaScript自定义浏览器滚动条兼容IE、 火狐和chrome
2017/01/05 Javascript
详解vue组件化开发-vuex状态管理库
2017/04/10 Javascript
javascript数组定义的几种方法
2017/10/06 Javascript
原生JS控制多个滚动条同步跟随滚动效果
2017/12/22 Javascript
webpack+vuex+axios 跨域请求数据的示例代码
2018/03/06 Javascript
JS字典Dictionary类定义与用法示例
2019/02/01 Javascript
记一次Vue.js混入mixin的使用(分权限管理页面)
2019/04/17 Javascript
使用vue-router切换页面时,获取上一页url以及当前页面url的方法
2019/05/06 Javascript
解决layui table表单提示数据接口请求异常的问题
2019/09/24 Javascript
浅谈layui数据表格判断问题(加入表单元素),设置单元格样式
2019/10/26 Javascript
[04:28]2014DOTA2国际邀请赛 采访小兔子LGD挺进钥匙体育馆
2014/07/14 DOTA
Python 解析XML文件
2009/04/15 Python
python中的字典使用分享
2016/07/31 Python
python2.7 mayavi 安装图文教程(推荐)
2017/06/22 Python
浅谈python 里面的单下划线与双下划线的区别
2017/12/01 Python
Python3 max()函数基础用法
2019/02/19 Python
python实现邮件自动发送
2019/08/10 Python
浅析python redis的连接及相关操作
2019/11/07 Python
python默认参数调用方法解析
2020/02/09 Python
django正续或者倒序查库实例
2020/05/19 Python
Python 日期与时间转换的方法
2020/08/01 Python
简单介绍CSS3中Media Query的使用
2015/07/07 HTML / CSS
使用CSS3实现多列布局与多背景的技巧
2016/02/29 HTML / CSS
探讨HTML5移动开发的几大特性(必看)
2015/12/30 HTML / CSS
英文简历中的自荐信范文
2013/12/14 职场文书
保护水资源的标语
2014/06/17 职场文书
标准单位租车协议书
2014/09/23 职场文书
党的群众路线教育实践活动制度建设计划
2014/11/03 职场文书