php二维数组用键名分组相加实例函数

 更新时间:2013年11月06日 09:36:54   作者:  
php二维数组以键名进行分组相加的实例程序
本文介绍一篇关于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);

相关文章

  • laravel 框架执行流程与原理简单分析

    laravel 框架执行流程与原理简单分析

    这篇文章主要介绍了laravel 框架执行流程与原理,结合实例形式分析了laravel框架基本执行流程、原理及相关操作技巧,需要的朋友可以参考下
    2020-02-02
  • Codeigniter中mkdir创建目录遇到权限问题和解决方法

    Codeigniter中mkdir创建目录遇到权限问题和解决方法

    这篇文章主要介绍了Codeigniter中mkdir创建目录遇到权限问题和解决方法,需要的朋友可以参考下
    2014-07-07
  • CI(CodeIgniter)模型用法实例分析

    CI(CodeIgniter)模型用法实例分析

    这篇文章主要介绍了CI(CodeIgniter)模型用法,结合实例形式分析了CodeIgniter框架中模型的功能、使用方法与相关注意事项,需要的朋友可以参考下
    2016-01-01
  • tp5.1 框架数据库高级查询技巧实例总结

    tp5.1 框架数据库高级查询技巧实例总结

    这篇文章主要介绍了tp5.1 框架数据库高级查询技巧,结合实例形式总结分析了tp5.1 框架数据库快捷查询、区间查询、批量查询、闭包查询等相关高级查询使用技巧,需要的朋友可以参考下
    2020-05-05
  • 基于Zend的Config机制的应用分析

    基于Zend的Config机制的应用分析

    本篇文章介绍了,基于Zend的Config机制的应用分析。需要的朋友参考下
    2013-05-05
  • tp5.0框架隐藏index.php入口文件及模块和控制器的方法分析

    tp5.0框架隐藏index.php入口文件及模块和控制器的方法分析

    这篇文章主要介绍了tp5.0框架隐藏index.php入口文件及模块和控制器的方法,结合实例形式分析thinkPHP5.0隐藏index.php入口文件及模块和控制器的具体配置方法、操作技巧与相关注意事项,需要的朋友可以参考下
    2020-02-02
  • php实现图片压缩处理

    php实现图片压缩处理

    这篇文章主要为大家详细介绍了php实现图片压缩处理,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-09-09
  • php预定义变量使用帮助(带实例)

    php预定义变量使用帮助(带实例)

    php取得外部变量的首选方法是用下面提及的超全局变量。在此之前,人们要么依赖 register_globals,要么就是长长的预定义 PHP 数组($HTTP_*_VARS)。自 PHP 5.0.0 起,长格式的 PHP 预定义变量可以通过设置 register_long_arrays 来屏蔽。
    2013-10-10
  • ThinkPHP实现二级循环读取的方法

    ThinkPHP实现二级循环读取的方法

    这篇文章主要介绍了ThinkPHP实现二级循环读取的方法,是ThinkPHP基于数组的数据库操作中非常常见的技巧,需要的朋友可以参考下
    2014-11-11
  • 详解关于php的xdebug配置(编辑器vscode)

    详解关于php的xdebug配置(编辑器vscode)

    这篇文章主要介绍了详解关于php的xdebug配置(编辑器vscode),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-01-01

最新评论