搜尋

首頁  >  問答  >  主體

thinkphp5 - thinkphp怎麼操作如果陣列裡有相關的陣列提取值後面相加?

我做一個商城裡面有個採購表,採購表裡面有訂單,有些訂單和另一些訂單的商品是一樣的,然後裡面字段amount是訂單這個商品的購買數量,我想判斷如果這個訂單和某個商品id是一樣就疊加amount欄位的數量,該怎麼做?

array(
    [0]=>
        'pid'=>7,
        'amount'=>1,
    [1]=>
        'pid'=>7,
        'amount'=>2,
    [2]=>
        'pid'=>8,
        'amount'=>1,
)

比如這數組,有2個pid值是一樣的,我就把他結合數值相加變成這一下數組

array(
    [0]=>
        'pid'=>7,
        'amount'=>3,
    [1]=>
        'pid'=>8,
        'amount'=>1,
    )
仅有的幸福仅有的幸福2830 天前671

全部回覆(4)我來回復

  • 伊谢尔伦

    伊谢尔伦2017-05-16 13:03:33

    使用pid作為新數組的鍵值

    $returnarr = array();
    foreach($data as $val) {
        if(isset($returnarr[$val['pid']])) {
            $returnarr[$val['pid']]['amount'] += $val['amount']; 
        } else {
            $returnarr[$val['pid']]['pid'] = $val['pid'];
            $returnarr[$val['pid']]['amount'] = $val['amount']; 
        }
    }

    回覆
    0
  • 怪我咯

    怪我咯2017-05-16 13:03:33

    寫個循環,根據pid 判斷是否存在相同的然後合併,最後產生一個新的陣列OK

    回覆
    0
  • phpcn_u1582

    phpcn_u15822017-05-16 13:03:33

    $allok = array();
                foreach ($all as $key1 => &$value1){
                    foreach ($value1 as $key2 => $value2){
                        $allok[$value2['pid']] = $value2;
                        $allok[$value2['pid']] = $allok[$value2['pid']]['amount'] + $value2['amount'];
                        /*$queryproductshop = Model('Product')->queryidshop($value2['pid']);
                        $queryshopclass = Model('ProductClassify')->SaleConfigShopClass($queryproductshop['cid']);
                        $queryproductshop['class'] = $queryshopclass['title'];
                        $allshop[] = $queryproductshop;*/
                    }
                }
                dump($allok);

    已經自己解決,自己想太複雜了

    回覆
    0
  • 我想大声告诉你

    我想大声告诉你2017-05-16 13:03:33

    //程式碼如下,希望對你有幫助。
    $orderInfo = array(

    [0]=>
        'pid'=>7,
        'amount'=>1,
    [1]=>
        'pid'=>7,
        'amount'=>2,
    [2]=>
        'pid'=>8,
        'amount'=>1,

    );
    foreach ($orderInfo as $k=>$v)

              {
                  $bKey=$v['pid'];
                  if(!array_key_exists($bKey, $orderArr)) 
                  {
                    $orderArr[$bKey] = [];
                    $sumData[$bKey] = 0;
                    }
                  $orderArr[$bKey]=$v;
                  $sumData[$bKey]+=$orderArr[$bKey]['amount']; 
                  $orderArr[$bKey]['amount']=$sumData[$bKey];
              }   
        var_dump($orderArr);       

    回覆
    0
  • 取消回覆