백엔드 개발 PHP 튜토리얼 php 二维数组以某一键名进行分组相加_PHP教程

php 二维数组以某一键名进行分组相加_PHP教程

Jul 13, 2016 am 10:50 AM
php 소개하다 ~에 의해 ~에 대한 그룹 동급생 정렬 기사 추가하다 지휘하다 키 이름

本文章来给各位同学介绍一篇关于php 二维数组以某一键名进行分组相加实例程序,希望此教程对各位同学会有所帮助。

如题,如果是从数据库里取数据的时候大可以

SELECT SUM(t_value),t_id FROM t_table GROUP BY t_id

但是如果是在php程序中处理类似的问题就稍微麻烦点了,这里给个函数就是处理类似的问题

 代码如下 复制代码

/* 函数功能:对二维数组以某一键名进行分组相加,返回新的二维数组 

 * 参数说明:$arr-源数组;$new_arr-相加后得到的新数组;$target_key-要分组的键名 

 */

function add_array($arr, &$new_arr, $target_key) { 

    $num = count($new_arr); //计算新数组的大小,新数组也是二维的,这里计算的是第一维 

    for ($i = 0; $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);

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/632663.htmlTechArticle本文章来给各位同学介绍一篇关于php 二维数组以某一键名进行分组相加实例程序,希望此教程对各位同学会有所帮助。 如题,如果是从数据...
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Dec 24, 2024 pm 04:42 PM

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드

CakePHP 날짜 및 시간 CakePHP 날짜 및 시간 Sep 10, 2024 pm 05:27 PM

CakePHP 날짜 및 시간

CakePHP 프로젝트 구성 CakePHP 프로젝트 구성 Sep 10, 2024 pm 05:25 PM

CakePHP 프로젝트 구성

CakePHP 파일 업로드 CakePHP 파일 업로드 Sep 10, 2024 pm 05:27 PM

CakePHP 파일 업로드

CakePHP 라우팅 CakePHP 라우팅 Sep 10, 2024 pm 05:25 PM

CakePHP 라우팅

CakePHP 토론 CakePHP 토론 Sep 10, 2024 pm 05:28 PM

CakePHP 토론

CakePHP 빠른 가이드 CakePHP 빠른 가이드 Sep 10, 2024 pm 05:27 PM

CakePHP 빠른 가이드

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 Dec 20, 2024 am 11:31 AM

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법

See all articles