根据子值合并多维数组的子数组
Merge subarrays of multidimensional array based on sub value
我有一个这样的多维数组,我需要合并具有相同messageID值的子数组。
$myarray = Array (
[0] => Array
(
[messageId] => 5ACE9D8841
[sender] => john@doe.com
)
[1] => Array
(
[messageId] => 7EE67D8170
[sender] => dan@doe.com
)
[2] => Array
(
[messageId] => 8095FD8836
[sender] => cat@doe.com
)
[3] => Array
(
[messageId] => 7EE67D8170
[dest] => mitch@doe.com
[status] => sent
[date] => 2021-02-01 11:06:55
)
);
预期结果,[1] 和 [3] 合并为 [1],因为它们共享相同的 [messageId] :
Array
(
[0] => Array
(
[messageId] => 5ACE9D8841
[sender] => john@doe.com
)
[1] => Array
(
[messageId] => 7EE67D8170
[dest] => mitch@doe.com
[status] => sent
[date] => 2021-02-01 11:06:55
[sender] => dan@doe.com
)
[2] => Array
(
[messageId] => 8095FD8836
[sender] => cat@doe.com
)
)
我不介意键索引或顺序。
编辑:我试过 array_merge、array_merge_recursive 和许多其他方法。使用
获得最佳结果
foreach ($myarray as $sub_arr) {
$result_arr = array_merge($result_arr, $sub_arr);
$result_arr = array_unique($result_arr);
}
有效,但 returns 仅最后一次迭代:
Array
(
[messageId] => 7EE67D8170
[dest] => mitch@doe.com
[status] => sent
[date] => 2021-02-01 11:06:55
[sender] => dan@doe.com
)
此致
尝试将 array_reduce
函数与回调函数一起使用:
$result = array_values(array_reduce($myarray, function($rows, $item){
if (array_key_exists('messageId', $item) && is_scalar($item['messageId'])) {
$rows = array_replace_recursive($rows ?? [], [$item['messageId'] => $item]);
}
return $rows;
}));
print_r($result);
我有一个这样的多维数组,我需要合并具有相同messageID值的子数组。
$myarray = Array (
[0] => Array
(
[messageId] => 5ACE9D8841
[sender] => john@doe.com
)
[1] => Array
(
[messageId] => 7EE67D8170
[sender] => dan@doe.com
)
[2] => Array
(
[messageId] => 8095FD8836
[sender] => cat@doe.com
)
[3] => Array
(
[messageId] => 7EE67D8170
[dest] => mitch@doe.com
[status] => sent
[date] => 2021-02-01 11:06:55
)
);
预期结果,[1] 和 [3] 合并为 [1],因为它们共享相同的 [messageId] :
Array
(
[0] => Array
(
[messageId] => 5ACE9D8841
[sender] => john@doe.com
)
[1] => Array
(
[messageId] => 7EE67D8170
[dest] => mitch@doe.com
[status] => sent
[date] => 2021-02-01 11:06:55
[sender] => dan@doe.com
)
[2] => Array
(
[messageId] => 8095FD8836
[sender] => cat@doe.com
)
)
我不介意键索引或顺序。
编辑:我试过 array_merge、array_merge_recursive 和许多其他方法。使用
获得最佳结果
foreach ($myarray as $sub_arr) {
$result_arr = array_merge($result_arr, $sub_arr);
$result_arr = array_unique($result_arr);
}
有效,但 returns 仅最后一次迭代:
Array
(
[messageId] => 7EE67D8170
[dest] => mitch@doe.com
[status] => sent
[date] => 2021-02-01 11:06:55
[sender] => dan@doe.com
)
此致
尝试将 array_reduce
函数与回调函数一起使用:
$result = array_values(array_reduce($myarray, function($rows, $item){
if (array_key_exists('messageId', $item) && is_scalar($item['messageId'])) {
$rows = array_replace_recursive($rows ?? [], [$item['messageId'] => $item]);
}
return $rows;
}));
print_r($result);