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
php中文本数据翻页(留言本翻页)
Oct 09 PHP
PHP6 mysql连接方式说明
Feb 09 PHP
php adodb分页实现代码
Mar 19 PHP
ThinkPHP php 框架学习笔记
Oct 30 PHP
php中设置index.php文件为只读的方法
Feb 06 PHP
windwos下使用php连接oracle数据库的过程分享
May 26 PHP
php单态设计模式(单例模式)实例
Nov 18 PHP
ThinkPHP提示错误Fatal error: Allowed memory size的解决方法
Feb 12 PHP
PHP抽奖算法程序代码分享
Oct 08 PHP
PHP实现图片上传并压缩
Dec 22 PHP
php实现等比例压缩图片
Jul 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
APMServ使用说明
2006/10/23 PHP
php header示例代码(推荐)
2010/09/08 PHP
WordPress判断用户是否登录的代码
2011/03/17 PHP
PHP引用(&amp;)各种使用方法实例详解
2014/03/20 PHP
php获取网页里所有图片并存入数组的方法
2015/04/06 PHP
PDO::rollBack讲解
2019/01/29 PHP
(仅IE下有效)关于checkbox 三态
2007/05/12 Javascript
一个判断email合法性的函数[非正则]
2008/12/09 Javascript
javascript 特性检测并非浏览器检测
2010/01/15 Javascript
IE6图片加载的一个BUG解决方法
2010/07/13 Javascript
自制轻量级仿jQuery.boxy对话框插件代码
2010/10/26 Javascript
jquery星级插件、支持页面中多次使用
2012/03/25 Javascript
XMLHttpRequest处理xml格式的返回数据(示例代码)
2013/11/21 Javascript
javascript制作坦克大战全纪录(2)
2014/11/27 Javascript
JQuery实现左右滚动菜单特效
2015/09/28 Javascript
莱鸟介绍javascript onclick事件
2016/01/06 Javascript
详解js的六大数据类型
2016/12/27 Javascript
浅谈Angular4实现热加载开发旅程
2017/09/08 Javascript
Node.js实现连接mysql数据库功能示例
2017/09/15 Javascript
vue 系列——vue2-webpack2框架搭建踩坑之路
2017/12/22 Javascript
Vue+Typescript中在Vue上挂载axios使用时报错问题
2019/08/07 Javascript
Vue实现渲染数据后控制滚动条位置(推荐)
2019/12/09 Javascript
element 中 el-menu 组件的无限极循环思路代码详解
2020/04/26 Javascript
[01:52]2020年DOTA2 TI10夏季活动预告片
2020/07/15 DOTA
用Python进行行为驱动开发的入门教程
2015/04/23 Python
Python的Flask框架应用调用Redis队列数据的方法
2016/06/06 Python
对python打乱数据集中X,y标签对的方法详解
2018/12/14 Python
Python实现的序列化和反序列化二叉树算法示例
2019/03/02 Python
关于HTML5+ API plusready的兼容问题
2020/11/20 HTML / CSS
2015年农村党员干部主题教育活动总结
2015/03/25 职场文书
同学会演讲稿
2019/04/02 职场文书
Python读取文件夹下的所有文件实例代码
2021/04/02 Python
MySQL 外键约束和表关系相关总结
2021/06/20 MySQL
MySQL的全局锁和表级锁的具体使用
2021/08/23 MySQL
B站评分公认最好看的动漫,你的名字评分9.9,第六备受喜欢
2022/03/18 日漫
mysql查看表结构的三种方法总结
2022/07/07 MySQL