我有两个多维数组,它们是关联行的索引数组。
$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
34
和56
在$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