日本搞逼视频_黄色一级片免费在线观看_色99久久_性明星video另类hd_欧美77_综合在线视频

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

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

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

如題,如果是從數據庫里取數據的時候大可以使用如下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); 
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 91在线精品秘密一区二区 | 久久成人国产 | 国产午夜精品一区二区三区 | 粉嫩国产15xxxxx | www.婷婷色| 美女国内精品自产拍在线播放 | 亚洲欧美一区二区三区国产精品 | 亚洲小少妇裸体bbw 亚洲免费成人 | 青青草福利视频 | 国产美女精品 | 久久久久久免费毛片 | 特黄av| 日韩成人小视频 | 日韩福利在线 | 一区二区久久久 | 国产精品一二区 | 国产精品99久久久久久大便 | 成人免费大片在线观看 | 999精品在线 | 一级黄色电影网站 | 日本一二区视频 | 久热国产精品视频一区二区三区 | 在线观看av资源 | 黄色片在线播放 | 黄色网页在线看 | 日韩a一级 | 日日噜噜噜夜夜爽爽狠狠视频, | 国产毛片精品 | 久久久夜精品 | 日韩在线观看网站 | 日韩毛片免费视频一级特黄 | 蜜臀91丨九色丨蝌蚪中文 | 日本午夜网| 国产福利在线看 | 大陆性猛交xxxx乱大交 | 久久综合久久综合久久 | 一级不卡 | 国产成人av在线播放 | 亚洲视频欧美视频 | 日韩在线欧美 | 久久永久免费 |