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 相关文章推荐
dede全站URL静态化改造[070414更正]
Apr 17 PHP
初学CAKEPHP 基础教程
Nov 02 PHP
php不用正则验证真假身份证
Nov 06 PHP
php5.2以下版本无json_decode函数的解决方法
May 25 PHP
PHP is_subclass_of函数的一个BUG和解决方法
Jun 01 PHP
Discuz批量替换帖子内容的方法(使用SQL更新数据库)
Jun 23 PHP
推荐10个提供免费PHP脚本下载的网站
Dec 31 PHP
Zend Guard使用指南及问题处理
Jan 07 PHP
基于PHP实现短信验证码接口(容联运通讯)
Sep 06 PHP
关于PHP通用返回值设置方法
Mar 31 PHP
php使用array_chunk函数将一个数组分割成多个数组
Dec 05 PHP
PHP 进程池与轮询调度算法实现多任务的示例代码
Nov 26 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
解决phpmyadmin中文乱码问题。。。
2007/01/18 PHP
php中cookie实现二级域名可访问操作的方法
2014/11/11 PHP
php构造函数与析构函数
2016/04/23 PHP
PHP 中使用explode()函数切割字符串为数组的示例
2017/05/06 PHP
多浏览器支持的右下角浮动窗口
2010/04/01 Javascript
浏览器脚本兼容 文本框中,回车键触发事件的兼容
2010/06/21 Javascript
jquery.hotkeys监听键盘按下事件keydown插件
2014/05/11 Javascript
jQuery 实现自动填充邮箱功能(带下拉提示)
2014/10/14 Javascript
使用jQuery.form.js/springmvc框架实现文件上传功能
2016/05/12 Javascript
AngularJS入门教程之AngularJS 模板
2016/08/18 Javascript
jQuery事件绑定方法学习总结(推荐)
2016/11/21 Javascript
移动端基础事件总结与应用
2017/01/12 Javascript
angularjs中回车键触发某一事件的方法
2017/04/24 Javascript
vue select二级联动第二级默认选中第一个option值的实例
2018/01/10 Javascript
在vue组件中使用axios的方法
2018/03/16 Javascript
js中如何完美的解析数据
2018/03/18 Javascript
Vue组件之单向数据流的解决方法
2018/11/10 Javascript
24个ES6方法解决JS实际开发问题(小结)
2020/05/31 Javascript
jQuery实现本地存储
2020/12/22 jQuery
[20:39]DOTA2-DPC中国联赛 正赛开幕式 1月18日
2021/03/11 DOTA
Python中的二叉树查找算法模块使用指南
2014/07/04 Python
详解python的四种内置数据结构
2019/03/19 Python
详解numpy.meshgrid()方法使用
2019/08/01 Python
详解pandas使用drop_duplicates去除DataFrame重复项参数
2019/08/01 Python
python多环境切换及pyenv使用过程详解
2019/09/27 Python
python web框架Flask实现图形验证码及验证码的动态刷新实例
2019/10/14 Python
python 实现兔子生兔子示例
2019/11/21 Python
使用python+whoosh实现全文检索
2019/12/09 Python
pytorch实现onehot编码转为普通label标签
2020/01/02 Python
基于spring boot 日志(logback)报错的解决方式
2020/02/20 Python
python给list排序的简单方法
2020/12/10 Python
英国最大的户外商店:Go Outdoors
2019/04/17 全球购物
社区优秀志愿者材料
2014/02/02 职场文书
工作会议主持词
2014/03/17 职场文书
酒店仓管员岗位职责
2014/04/28 职场文书
如何拟写通知正文?
2019/04/02 职场文书