
[英]Merging two multidimensional arrays while deleting duplicates, relying about a specific element of them
[英]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.