多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > php開源 > php教程 > php 二維數組以某一鍵名進行分組相加

php 二維數組以某一鍵名進行分組相加

來源:程序員人生   發布時間:2013-12-17 14:25:14 閱讀次數:2812次

如題,如果是從數據庫里取數據的時候大可以使用如下SQL

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

但是如果是在php程序中處理類似的問題就稍微麻煩點了,這里給個函數就是處理類似的問題,實例代碼如下:

  1. <?php  
  2. /* 函數功能:對二維數組以某一鍵名進行分組相加,返回新的二維數組  
  3.  * 參數說明:$arr-源數組;$new_arr-相加后得到的新數組;$target_key-要分組的鍵名  
  4.  */ 
  5. function add_array($arr, &$new_arr$target_key) {  
  6.     $num = count($new_arr); //計算新數組的大小,新數組也是二維的,這里計算的是第一維  
  7.     for ($i = 0; $i < $num$i++) {  
  8.         //循環新數組  
  9.         //if塊主要判斷當前分組的鍵名是否已經存在于新數組中,避免重復  
  10.         //由于該函數是被循環調用的,而新數組可能有多于1個的元素,所以必須對新數組中的每一個元素都進行比較,  
  11.         //新數組的元素是一個一維數組,$i動態的比較新的二維數組中的分組鍵名  
  12.         if ($arr[$target_key] != $new_arr[$i][$target_key]) {//判斷新數組中的分組鍵名是否跟當前源數組中的分組鍵名相等  
  13.             $cmp_num++; //如果不相等,比較次數自增1  
  14.         } else {//如果相等,說明當前分組鍵名已經存在  
  15.             $tar_exist = true; //設置存在標識為true  
  16.             $tar_key = $i//返回當前分組鍵名在新數組中的數字索引  
  17.             break//跳出循環  
  18.         }  
  19.     }  
  20.     //如果比較次數跟新數組大小一樣,說明當前分組鍵名不在新數組中,設置存在標識為false  
  21.     if ($cmp_num == $num)  
  22.         $tar_exist = false;  
  23.     if ($tar_exist) {//如果分組鍵名已經存在,對該分組的數組元素進行相加  
  24.         foreach ($arr as $key => $value) {  
  25.             if ($key != $target_key) {//分組鍵名對應的元素值不相加  
  26.                 $new_arr[$tar_key][$key]+=$value//其余的元素值進行相加  
  27.             }  
  28.         }  
  29.     } else {  
  30.         //如果分組鍵名不存在  
  31.         //設置新的分組鍵名,并對該分組的數組元素進行相加  
  32.         //新數組的第一維使用$num參數來分辨當前分組的秩序  
  33.         //由于$num實際上就是新數組中,按鍵名分組的個數,并且是從0開始,所以新的分組在新數組中的索引直接用$num即可,  
  34.         //而不須要$num+1  
  35.         $new_arr[$num][$target_key] = $arr[$target_key];  
  36.         foreach ($arr as $key => $value) {  
  37.             if ($key != $target_key) {//分組鍵名對應的元素值不相加  
  38.                 $new_arr[$num][$key]+=$value//其余的元素值進行相加  
  39.             }  
  40.         }  
  41.     }  
  42. }  
  43. $arr = array(  
  44.     array('group_id' => 13, 'team_price' => 88.00, 'satopay_price' => 85.00, 'team_id' => 348, 'origin' => 440, 'gain' => 14.45, 'quantity' => 5),  
  45.     array('group_id' => 13, 'team_price' => 12.00, 'satopay_price' => 11.00, 'team_id' => 344, 'origin' => 36, 'gain' => 2.76, 'quantity' => 3),  
  46.     array('group_id' => 14, 'team_price' => 4.99, 'satopay_price' => 4.60, 'team_id' => 335, 'origin' => 4.99, 'gain' => 0.31915, 'quantity' => 1),  
  47.     array('group_id' => 14, 'team_price' => 12.00, 'satopay_price' => 11.00, 'team_id' => 344, 'origin' => 24, 'gain' => 1.84, 'quantity' => 2),  
  48.     array('group_id' => 15, 'team_price' => 13.00, 'satopay_price' => 11.00, 'team_id' => 344, 'origin' => 24, 'gain' => 1.84, 'quantity' => 2),  
  49. );  
  50. $new_arr = array();  
  51. foreach ($arr as $key => $value) {  
  52.     add_array($value, &$new_arr'group_id'); //這里我們按group_id進行分組相加  
  53. }  
  54. var_dump($new_arr); 
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 最近最新的中文字幕大全3 最近最新高清免费中文字幕 | 国产亚洲综合激情校园小说 | 欧美激情久久久久久久久 | 在线欧美色 | 精品国产福利在线观看一区 | 亚洲天堂网视频 | 嗯啊羞羞视频在线观看动漫 | 亚洲国产精品综合福利专区 | aaaaaa级特色特黄的毛片 | 正在播放国产露脸真实高清 | v影院最新在线v视频 | 在线观看亚洲欧美 | 福利影院第一页 | 香蕉大成网人站在线 | 在线观看亚洲人成网站 | 最近最中文字幕视频 | xxxxx性视频免费播放 | 91亚洲欧美综合高清在线 | 欧美hd性 | 亚洲成人在线网 | 国产高清一区二区三区免费视频 | 欧美一级日本一级韩国一级 | 成人欧美一区二区三区小说 | 中文字幕欧美日韩一 | 免费观看的黄色网址 | 亚洲最新黄色网址 | 日本不卡免费高清一级视频 | 日本www高清免费视频观看 | 性欧美video另类hd尤物 | 亚洲片在线 | 亚洲乱码一二三四区国产 | 久久亚洲伊人 | 欧美人xxxx| 最好看的最新中文字幕2018免费视频 | 可以免费观看全网 | 亚洲精品aⅴ中文字幕乱码 亚洲精品h | 秋霞特色aa大片在线观看 | 欧美成在线观看 | 亚洲欧美小说 | 久久www免费人成_看片高清 | 国产精品成人观看视频国产 |