根据子值合并多维数组的子数组

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);

fiddle