如何检查键数组是否具有相同的值或多个

时间:2019-07-30 02:00:58

标签: php mysql arrays foreach

我有一个数组(变量$ items),其中存在相同的invenid(不止一个),如何检查是否存在多个invenid,以及如何从每个现有数组中添加total_price并创建一个新键折扣价。 这是我的数组: array ![array] [1]

function apply_promotion($items){   
        foreach($items as $key => $val){
            if(isset($val['promo'])){
                $promo_type = $val['promo']['slug'];
                $start_date = $val['promo']['startdate'];
                $end_date = $val['promo']['enddate'];
                if(($start_date != '0000-00-00') && ($end_date != '0000-00-00') && (strtotime(timetodate(DT_TIME, 3)) >= strtotime($start_date)) && (strtotime(timetodate(DT_TIME, 3)) <= strtotime($end_date))){
                    switch($promo_type){
                        case "item-promotion":
                            $purchase = dround($val['total_price'], 2, 1);
                            if($purchase >= $val['promo']['min_purchase'] && empty($val['promo_code'])){
                                $items[$key]['discount_price']= dround($val['promo']['discount_amount'], 2, 1);
                            }
                            break;
                    }
                }
            }
        }

        echo '<pre>'.print_r($items, 1).'</pre>';die();
        return $items;
    }

3 个答案:

答案 0 :(得分:1)

您可以将foreach与参考传递一起使用

 foreach($a as $key => &$val){
   ($val['invenid'] > 1) ? ($val['total_price'] = 12.00) : '';
 }

DEMO

答案 1 :(得分:0)

尝试使用array_keys()

例如:

$array1 = array([0],[1]);

print_r(array_keys($array1));

它将返回数组中的所有键

更多信息,您可以找到here

答案 2 :(得分:0)

使用array_unique()函数,它将从数组中删除重复的值。如果两个或多个数组值相同,则第一个外观将保留,而另一个外观将被删除