繁体   English   中英

合并两个多维数组,同时将它们相交并求和

[英]Merging two multidimensional arrays while intersecting them and sum the values

我有两个多维数组。 这些是-

Array
(
    [Fortitude] => Array
        (
            [library_count] => 0
            [crypt_count] => 7
        )

    [Obtenebration] => Array
        (
            [library_count] => 6
            [crypt_count] => 11
        )

    [Dementation] => Array
        (
            [library_count] => 1
            [crypt_count] => 0
        )

    [Obfuscate] => Array
        (
            [library_count] => 0
            [crypt_count] => 2
        )

    [Necromancy] => Array
        (
            [library_count] => 9
            [crypt_count] => 2
        )

    [Celerity] => Array
        (
            [library_count] => 0
            [crypt_count] => 1
        )

    [Redemption] => Array
        (
            [library_count] => 1
            [crypt_count] => 0
        )

    [Dominate] => Array
        (
            [library_count] => 19
            [crypt_count] => 2
        )

    [Auspex] => Array
        (
            [library_count] => 1
            [crypt_count] => 0
        )

    [Potence] => Array
        (
            [library_count] => 1
            [crypt_count] => 2
        )

)

Array
(
    [Dominate] => Array
        (
            [library_count] => 19
            [crypt_count] => 7
        )

    [Celerity] => Array
        (
            [library_count] => 0
            [crypt_count] => 6
        )

    [Auspex] => Array
        (
            [library_count] => 1
            [crypt_count] => 2
        )

    [Obtenebration] => Array
        (
            [library_count] => 6
            [crypt_count] => 0
        )

    [Necromancy] => Array
        (
            [library_count] => 9
            [crypt_count] => 1
        )

    [Potence] => Array
        (
            [library_count] => 1
            [crypt_count] => 1
        )

)

..这些数组具有一些相似的键,例如“ Celerity”。 我想在两个数组中都找到公用密钥,并总结它们的库和加密计数,并使其成为一个数组。

您可以将array_intersect()array_keys()结合使用,以找到在两个数组中都使用的键。 然后,遍历键以创建新数组:

$keys1 = array_keys($arr1);
$keys2 = array_keys($arr2);
$common_keys = array_intersect($keys1, $keys2) ;
$diff_keys = array_diff($keys1, $keys2);

$out = [];
foreach ($diff_keys as $diff) {
    if (isset($arr1[$diff])) $out[$diff] = $arr1[$diff];
    else $out[$diff] = $arr2[$diff];
}
foreach ($common_keys as $key) {
    $out[$key] = $arr1[$key] ;
    $out[$key]['library_count'] += $arr2[$key]['library_count'];
    $out[$key]['crypt_count'] += $arr2[$key]['crypt_count'];
}
print_r($out);

输出:

Array
(
    [Fortitude] => Array
        (
            [library_count] => 0
            [crypt_count] => 7
        )

    [Dementation] => Array
        (
            [library_count] => 1
            [crypt_count] => 0
        )

    [Obfuscate] => Array
        (
            [library_count] => 0
            [crypt_count] => 2
        )

    [Redemption] => Array
        (
            [library_count] => 1
            [crypt_count] => 0
        )

    [Obtenebration] => Array
        (
            [library_count] => 12
            [crypt_count] => 11
        )

    [Necromancy] => Array
        (
            [library_count] => 18
            [crypt_count] => 3
        )

    [Celerity] => Array
        (
            [library_count] => 0
            [crypt_count] => 7
        )

    [Dominate] => Array
        (
            [library_count] => 38
            [crypt_count] => 9
        )

    [Auspex] => Array
        (
            [library_count] => 2
            [crypt_count] => 2
        )

    [Potence] => Array
        (
            [library_count] => 2
            [crypt_count] => 3
        )

)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM