php 2 D配列キー名パケット加算インスタンス関数

3428 ワード

本稿では、php 2次元配列をあるキー名でグループ化する例について説明します.データベースからデータを取得する場合、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 < $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);