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 相关文章推荐
利用递归把多维数组转为一维数组的函数
Oct 09 PHP
php 404错误页面实现代码
Jun 22 PHP
利用PHP实现图片等比例放大和缩小的方法详解
Jun 06 PHP
php实现利用phpexcel导出数据
Aug 24 PHP
设置php页面编码的两种方法示例介绍
Mar 03 PHP
php 邮件发送问题解决
Mar 22 PHP
PHP数组和explode函数示例总结
May 08 PHP
PHP文件操作之获取目录下文件与计算相对路径的方法
Jan 08 PHP
PHP实现原生态图片上传封装类方法
Nov 08 PHP
PHP实现Session入库/存入redis的方法
May 04 PHP
PHP实现动态删除XML数据的方法示例
Mar 30 PHP
解决Laravel 不能创建 migration 的问题
Oct 09 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中使用curl_init函数的说明
2010/11/02 PHP
php学习笔记之 函数声明(二)
2011/06/09 PHP
记Laravel调用Gin接口调用formData上传文件的实现方法
2019/12/12 PHP
利用Ext Js生成动态树实例代码
2008/09/08 Javascript
JavaScript+CSS实现仿Mootools竖排弹性动画菜单效果
2015/10/14 Javascript
JQuery.validate在ie8下不支持的快速解决方法
2016/05/18 Javascript
jquery插件autocomplete用法示例
2016/07/01 Javascript
javascript实现复选框全选或反选
2017/02/04 Javascript
微信小程序 setData使用方法及常用错误解决办法
2017/05/11 Javascript
详解vue-cli + webpack 多页面实例配置优化方法
2017/07/13 Javascript
JavaScript对JSON数据进行排序和搜索
2017/07/24 Javascript
JS Testing Properties 判断属性是否在对象里的方法
2017/10/01 Javascript
jQuery实现的下雪动画效果示例【附源码下载】
2018/02/02 jQuery
vue v-for循环重复数据无法添加问题解决方法【加track-by='索引'】
2019/03/15 Javascript
vue 实现滚动到底部翻页效果(pc端)
2019/07/31 Javascript
Vue2.0 实现页面缓存和不缓存的方式
2019/11/12 Javascript
vue中实现点击变成全屏的多种方法
2020/09/27 Javascript
python实现将英文单词表示的数字转换成阿拉伯数字的方法
2015/07/02 Python
Ubuntu安装Jupyter Notebook教程
2017/10/18 Python
详解python实现识别手写MNIST数字集的程序
2018/08/03 Python
对python多线程与global变量详解
2018/11/09 Python
pygame游戏之旅 游戏中添加显示文字
2018/11/20 Python
html通过canvas转成base64的方法
2019/07/18 HTML / CSS
Omio法国:全欧洲低价大巴、火车和航班搜索和比价
2017/11/13 全球购物
天逸系统(武汉)有限公司Java笔试题
2015/12/29 面试题
一组SQL面试题
2016/02/15 面试题
小学岗位竞聘方案
2014/01/22 职场文书
申请任职学生会干部自荐书范文
2014/02/13 职场文书
暑期培训心得体会
2014/09/02 职场文书
房屋租房协议书范本
2014/12/04 职场文书
国家助学贷款承诺书
2015/04/30 职场文书
董事长新年致辞
2015/07/29 职场文书
关爱空巢老人感想
2015/08/11 职场文书
给校长的建议书作文300字
2015/09/14 职场文书
python四种出行路线规划的实现
2021/06/23 Python
mysql如何能有效防止删库跑路
2021/10/05 MySQL