array_diff() 基于具有关联行的两个数组之间的一列


array_diff() based on one column between two arrays with associative rows

我有两个多维数组,它们是关联行的索引数组。

$array1 = array(
    array('name' => 'foo', 'id' => 12),
    array('name' => 'bar', 'id' => 34),
    array('name' => 'boo', 'id' => 56),
);
$array2 = array(
    array('name' => 'bar', 'id' => 34),
    array('name' => 'boo', 'id' => 56),
    array('name' => 'bar', 'id' => 78),
);

行可能具有不同的id值,但具有相同的name值 - 例如bar在我的示例输入数据中。

我只需要根据id值比较数组。

预期输出:(因为id 3456$array2中找到)

array(
    array('name' => 'foo', 'id' => 12)
)

我尝试了$one_not_two = array_diff($array1['id'], $array2['id']);它没有返回任何内容。

我也尝试了$one_not_two = array_diff($array1['id'], $array2['id']);
返回错误"参数不是数组"。

最初,我通过将id提取到一维数组中,然后只是比较它们来绕过它。 现在,我们应用程序中的一项新功能要求我在保持多维结构的同时比较行。有什么建议吗?

我们的服务器目前运行的是php 5.3,如果这有什么不同的话。

因为数组是多维的,所以你必须像这样提取 id:

$ids1 = array();
foreach($array1 as $elem1)
    $ids1[] = $elem1['id'];
$ids2 = array();
foreach($array2 as $elem2)
    $ids2[] = $elem2['id'];
$one_not_two = array_diff($ids1,$ids2);

对于您的特定问题,请查看带有多维数组的 array_diff()

您可以使用

array_udiff创建自定义差异函数:

$diff = array_udiff($array1,
                    $array2,
                    function ($a, $b){
                        if($a['id'] == $b['id']){
                            return 0;
                        } else {
                            return ($a['id'] < $b['id'] ? -1 : 1);
                        }
                    }
                );

http://codepad.viper-7.com/2u5EWg

如果 id 是唯一的,你可以这样做:

$one_not_two = array();
foreach ($array1 as $val) {
    $one_not_two[$val['id']] = $val;
}
foreach ($array1 as $val) {
    if (!isset($one_not_two[$val['id']])) {
        $one_not_two[$val['id']] = $val;
}

最后,我通过将 Array1 更改为name => id的关联数组来解决它

有和你一样的问题。

用:$result = array_diff_assoc($array2, $array1);

解决

参考: PHP: array_diff_assoc