比较PHP中两个多维数组之间的值

时间:2018-03-19 09:23:31

标签: php arrays duplicates

我在下面有PHP代码,它将检查两个关联数组。我的问题是,这段代码执行了很多循环,我不想要它,因为它会影响我的应用程序的性能。 PHP中是否有任何方法或功能可以自动检测重复?结果跟我的一样。

请检查示例here

这是我的代码:

// first Array
$m1Array = array();
$m1Array[] = array('eId' => '0001', 'numVal' => 1);
$m1Array[] = array('eId' => '0002', 'numVal' => 2);
$m1Array[] = array('eId' => '0003', 'numVal' => 3);
$m1Array[] = array('eId' => '0004', 'numVal' => 4);
$m1Array[] = array('eId' => '0005', 'numVal' => 5);
$m1Array[] = array('eId' => '0006', 'numVal' => 6);

//second Array
$m2Array = array();
$m2Array[] = array('eId' => '0001', 'numVal' => 1);
$m2Array[] = array('eId' => '0004', 'numVal' => 4);
$m2Array[] = array('eId' => '0005', 'numVal' => 5);
$m2Array[] = array('eId' => '0006', 'numVal' => 6);
$m2Array[] = array('eId' => '0007', 'numVal' => 7);

//final result array
$finalResult = array();


//[seond array] will be my master or the bases
//loop thru the [second array(m2Array)]
foreach($m2Array as $m2Arr){

    $numValSum  = 0;
    $dupFound   = false;

    //get current eId value in [second array]
    $eId2 = $m2Arr['eId'];

    //loop thru the [first array(m1Array)] to check if eId2 has duplicate
    $arrIndex = 0;
    foreach($m1Array as $m1Arr){

        //get current eId value in [first array]
        $eId1 = $m1Arr['eId'];

        //check if the value of eId2 is equal to eId 1
        if($eId1 == $eId2){
            //if equal then
            //add their respective numVal value and put it to [final result array]
            $numValSum      = $m2Arr['numVal'] + $m1Arr['numVal'];
            $finalResult[]  = array('eId' => $eId2, 'numValSum' => $numValSum);

            unset($m1Array[$arrIndex]); //remove the duplicate eId in [first array]
            sort($m1Array);             //sort the index of [first array]

            $dupFound   = true;
        }

    $arrIndex += 1;
    }

    //if eId2 has no duplicate then just add the numVal to [final result array]
    if($dupFound == false){
        $finalResult[]  = array('eId' => $eId2, 'numValSum' => $m2Arr['numVal']);
    }

}

//now check if [second array] still have an element
//if still have then add all to [final result array]
if(count($m1Array)){
    foreach($m1Array as $m1Arr){
        $finalResult[]  = array('eId' =>  $m1Arr['eId'], 'numValSum' => $m1Arr['numVal']);
    }
}


//display my final result array
foreach($finalResult as $fRes){
   echo $fRes['eId'].' -> '.$fRes['numValSum'].PHP_EOL;
}

其他信息:

道歉,但我想你们有些人错过了我的代码。我不想删除数组中的重复项。代码将检查重复下注。两个数组,如果eId在另一个数组中有重复,则在将其添加到我的numValoutput之前添加相应的finalResult array。但如果没有重复,请将其直接放到我的finalResult array

我附上了表格图,说明了它的工作原理。希望这可以帮助。谢谢。

here

2 个答案:

答案 0 :(得分:1)

您可以使用array_udiff()59代码行缩减为3,以获得两个多维数组之间的差异。它接受数据比较功能:

var_dump(array_udiff($m1Array, $m2Array, function($a, $b) {
    return $a["eId"] - $b["eId"];
}));

php中没有这样的功能,所以你可以把它分解成碎片:

$finalResult = $a1 = array_column($m1Array, "numVal", "eId");
$a2 = array_column($m2Array, "numVal", "eId");

array_walk($finalResult, function(&$item, $key) use ($a2) {
    if(isset($a2[$key])) $item += $a2[$key];
});

$finalResult = array_merge($finalResult, array_diff_key($a2, $finalResult));
// Array ( [0001] => 2 [0002] => 2 [0003] => 3 [0004] => 8 [0005] => 10 [0006] => 12 [0007] => 7 )

答案 1 :(得分:0)

解决方案是使用哈希表。除了拥有对象列表之外,还可以使用eId作为键,这样就可以避免嵌套循环并只查找键,例如:

$allKeys = array_unique( array_merge( array_keys($m1Array), array_keys($m2Array) ) );

foreach ($allKeys as $k) {
   if (isset($m1Array[$k]) and isset($m2Array[$k]) ) {
      // duplicate
   }  
}