공유 키 합계로 여러 평면 연관 배열 병합
array_merge() 함수로 연관 배열을 결합할 때 공유 키와 연관된 값 합산되기보다는 대체되는 경향이 있습니다. 이는 여러 연관 배열에서 공유 키 값을 추가하려고 할 때 문제가 됩니다.
이 장애물을 극복하려면 다음과 같은 여러 접근 방식을 채택할 수 있습니다.
$sums = array();
foreach (array_keys($a1 $a2) as $key) {
$sums[$key] = (isset($a1[$key]) ? $a1[$key] : 0) (isset($a2[$key]) ? $a2[$key] : 0);
}
$keys = array_fill_keys(array_keys($a1 $a2), 0);
$sums = array_map(function ($a1, $a2) { return $a1 $a2; }, array_merge($keys, $a1), array_merge($keys, $a2));
$sums = array_fill_keys(array_keys($a1 $a2), 0);
array_walk($sums, function (&$value, $key, $arrs) { $value = @($arrs[0][$key] $arrs[1][$key]); }, array($a1, $a2));
function array_sum_identical_keys() {
$arrays = func_get_args();
$keys = array_keys(array_reduce($arrays, function ($keys, $arr) { return $keys $arr; }, array()));
$sums = array();
foreach ($keys as $key) {
$sums[$key] = array_reduce($arrays, function ($sum, $arr) use ($key) { return $sum @$arr[$key]; });
}
return $sums;
}
이러한 접근 방식은 여러 연관 배열을 병합하고 공유 키와 연관된 값을 합산하기 위한 유연한 솔루션을 제공합니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3