簡體   English   中英

php從兩個不同的數組中搜索多維數組鍵值

[英]php multidimensional array key value search from two different arrays

我有兩個不同的數組。 數組就像

第一個數組就像

Array
(
    [0] => Array
        (
            [source_language] => English
            [target_language] => Array
                (
                    [0] => German
                    [1] => Norwegian
                )

            [title] => file 1.xlsx
            [file_name] => 1461911750_file_test.xlsx
        )

    [1] => Array
        (
            [source_language] => Hindi
            [target_language] => Array
                (
                    [0] => Belarusian
                )

            [title] => new files.xlsx
            [file_name] => 1461912206_file_here_files.xlsx
        )

)

第二個數組就像

Array
(
    [1] => Array
        (
            [source_language] => English
            [target_language] => Array
                (
                    [0] => Urdu
                    [1] => Hindi
                )

        )

    [2] => Array
        (
            [source_language] => Hindi
            [target_language] => Array
                (
                    [0] => Norwegian
                )

        )
    [3] => Array
        (
            [source_language] => Hindi
            [target_language] => Array
                (
                    [0] => German
                )

        )
    [3] => Array
        (
            [source_language] => English
            [target_language] => Array
                (
                    [0] => German
                    [1] => Norwegian
                )

        )                

)

現在,您可以為source_langaugetarget_language排列相同的鍵。 titlefile_name鍵僅在第一個數組中可用

所以我希望第一個數組將從第二個數組中搜索所有 source_language 和 target_language 並顯示匹配數組和非匹配數組

所以輸出應該是這樣的

The matching array is

[0] => Array
    (
        [source_language] => English
        [target_language] => Array
            (
                [0] => German
                [1] => Norwegian
            )

        [title] => file 1.xlsx
        [file_name] => 1461911750_file_test.xlsx
    )

因為它在第二個數組中具有相同的源語言和目標語言值

另一個結果將顯示是

non matching array is

[0] => Array
    (
        [source_language] => Hindi
        [target_language] => Array
            (
                [0] => Belarusian
            )

        [title] => new files.xlsx
        [file_name] => 1461912206_file_here_files.xlsx
    )

因為在第二個數組中找不到此源語言和目標語言。

更新

到目前為止我已經嘗試過

$diffs = [];

        foreach ($first_array as $a1) {
          $h1 = md5(json_encode($a1));
          $found = false;

          foreach ($second_array as $a2) {
            if (md5(json_encode($a2)) == $h1) {
              $found = true;
              break;
            }
          }


          if ( !$found ) {
            $diffs []= $a1;
          }
        }

但這個根本不起作用

首先,您不能將$h1$a2進行比較,因為它們不共享完全相同的結構。

$h1仍然具有titlefilename密鑰對值。

無需使用md5json_encode ,因為您只需要比較兩個字符串值:

$match = $no_match = array();
foreach($first as $f) {
    $found = false;
    foreach($second as $s) {
        if(
            $f['source_language'] === $s['source_language'] &&
            $f['target_language'] === $s['target_language']
            ) {
            $match[] = $f;
            $found = true;
        }
    }
    if(!$found) {
        $no_match[] = $f;
    }
}
<?php
$arr1 = array();
$arr2 = array();
$arr1[0] = array('source_language'=>'English','target_language'=>array('German','Norwegian'),'title'=>'file 1.xlsx','file_name'=>'1461911750_file_test.xlsx');

$arr1[1] = array('source_language'=>'Hindi','target_language'=>array('Belarusian'),'title'=>'new files.xlsx','file_name'=>'1461912206_file_here_files.xlsx');

$arr2[0] = array('source_language'=>'English','target_language'=>array('Urdu','Hindi'));
$arr2[1] = array('source_language'=>'Hindi','target_language'=>array('Norwegian'));
$arr2[2] = array('source_language'=>'Hindi','target_language'=>array('German'));
$arr2[3] = array('source_language'=>'English','target_language'=>array('German','Norwegian'));

$result_arr = array();
for($i=0;$i<count($arr2);$i++)
{
    for($j=0;$j<count($arr1);$j++)
    {
        if(($arr2[$i]['source_language'] === $arr1[$j]['source_language']) && ($arr2[$i]['target_language'] === $arr1[$j]['target_language'])) 
            $result_arr[] = $arr1[$j];
    }
}

print_r(json_encode($result_arr));

?>

使用array_walkarray_diff函數的解決方案:

$matched = $not_matched = [];
array_walk($array1, function($v) use($array2, &$matched, &$not_matched){
    foreach ($array2 as $item) {
        if ($v['source_language'] == $item['source_language']
            && empty(array_diff($v['target_language'], $item['target_language']))) {
            $matched[] = $v;
            break;
        }
    }
    if (!in_array($v, $matched)) $not_matched[] = $v;
});

echo "Matched items:". PHP_EOL;
print_r($matched);

echo "Not-matched items:". PHP_EOL;
print_r($not_matched);

輸出:

Matched items:
Array
(
    [0] => Array
        (
            [source_language] => English
            [target_language] => Array
                (
                    [0] => German
                    [1] => Norwegian
                )

            [title] => file 1.xlsx
            [file_name] => 1461911750_file_test.xlsx
        )
)

Not-matched items:
Array
(
    [0] => Array
        (
            [source_language] => Hindi
            [target_language] => Array
                (
                    [0] => Belarusian
                )

            [title] => files.xlsx
            [file_name] => 1461912206_file_here_files.xlsx
        )
)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM