简体   繁体   English

删除与另一个多维数组共享一个键-值对的子数组

[英]Removing subarrays that share a key-value pair with another multidimensional array

I have 2 arrays as below. 我有以下两个数组。 I want to remove data from array2 if array1 has the stu_id . 如果array1具有stu_id我想从array2删除数据。 final array should be like result_array . 最终数组应类似于result_array

$array1 = Array
(
    [0] => Array
        (
            [stu_id] => 1
            [name] => mr.a
        )
    [1] => Array
        (
            [stu_id] => 3
            [name] => mr.b
        )
)

$array2 = Array
(
    [0] => Array
        (
            [id] => 1
            [stu_id] => 1
            [data] => abc
        )
    [1] => Array
        (
            [id] => 2
            [stu_id] => 2
            [data] => xyz
        )
    [3] => Array
        (
            [id] => 3
            [stu_id] => 3
            [data] => aaa
        )
)

$result_array = Array
(
    [0] => Array
        (
            [id] => 2
            [stu_id] => 2
            [data] => xyz
        )
)

I tried array_diff, $result_array = array_diff($array2, $array1); 我尝试了array_diff, $result_array = array_diff($array2, $array1); but it's not working. 但它不起作用。

Please help me to do this. 请帮我做到这一点。

Temporarily assign keys using array_column() with stud_id ( NULL retains the full subarray data), then use array_diff_key() to filter, and array_values() to reset the keys: 使用带有stud_id array_column()临时分配键( NULL保留完整的子stud_id数据),然后使用array_diff_key()进行过滤,并使用array_values()重置键:

Code: ( Demo ) 代码:( 演示

$array1=[
    ['stu_id'=>1,'name'=>'mr.a'],
    ['stu_id'=>3,'name'=>'mr.b']
];

$array2=[
    ['id'=>1,'stu_id'=>1,'data'=>'abc'],
    ['id'=>2,'stu_id'=>2,'data'=>'xyz'],
    ['id'=>3,'stu_id'=>3,'data'=>'aaa']
];

//var_export(array_column($array1,NULL,'stu_id'));
//var_export(array_column($array2,NULL,'stu_id'));
var_export(array_values(array_diff_key(array_column($array2,NULL,'stu_id'),array_column($array1,NULL,'stu_id'))));

Output: 输出:

array (
  0 => 
  array (
    'id' => 2,
    'stu_id' => 2,
    'data' => 'xyz',
  ),
)

If you'd like to use a foreach loop structure, generate a filtering array of stu_id 's from $array1 and write a conditional check on each iteration of $array2 . 如果要使用foreach循环结构,请从$array1生成stu_id的过滤数组, stu_id $array2每次迭代编写条件检查。 This method doesn't not modify the original arrays, so they can be reused "down script". 此方法不会修改原始数组,因此可以在“向下脚本”中重用它们。

Code: 码:

$stu_ids=array_column($array1,'stu_id');
foreach($array2 as $row){
    if(!in_array($row['stu_id'],$stu_ids)){
        $result[]=$row;  // auto-index the qualifying subarrays
    }
}
var_export($result);
// same result as above method
foreach($array1 as $data1){
    foreach($array2 as $k => $data2){
        if($data2["stu_id"] == $data1["stu_id"]){
            unset($array2[$k]);
            break;
        }
    }
}
$result_array = $array2;

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM