PHP - 多维数组中值唯一的数组

时间:2015-02-23 10:09:51

标签: php arrays multidimensional-array

我想只删除输入数组中的重复项user_id

输入数组:

array (size=3)
  0 => 
    array (size=3)
      'user_id' => string '3' (length=1)
      'rate' => string '0' (length=1)
      'note' => string 'a' (length=1)
  1 => 
    array (size=3)
      'user_id' => string '3' (length=1)
      'rate' => string '2' (length=1)
      'note' => string 'b' (length=1)
  2 => 
    array (size=3)
      'user_id' => string '4' (length=1)
      'rate' => string '3' (length=1)
      'note' => string 'c' (length=1)

输出:

array (size=3)
  0 => 
    array (size=3)
      'user_id' => string '3' (length=1)
      'rate' => string '0' (length=1)
      'note' => string 'a' (length=1)
  1 => 
    array (size=3)
      'user_id' => string '4' (length=1)
      'rate' => string '3' (length=1)
      'note' => string 'c' (length=1)

到目前为止:

$result1 = array_unique($inputArray, SORT_REGULAR);
$result2 = array_map("unserialize", array_unique(array_map("serialize", $inputArray)));

5 个答案:

答案 0 :(得分:2)

这应该适合你:

<?php

    $arr = array(
            array(
                'user_id' => '3',
                'rate' => '0',
                'note' => 'a'
            ),
            array(
                'user_id' => '3',
                'rate' => '2',
                'note' => 'b'
            ),
            array(
                'user_id' => '4',
                'rate' => '3',
                'note' => 'c' 
            )
        );

    $tmp = array();

    foreach($arr as $key => $innerArray) {
        if(in_array($innerArray["user_id"], $tmp))
            unset($arr[$key]);
        else
            $tmp[] = $innerArray["user_id"];
    }

    print_r($arr);

?>

修改

如果您想要更多 fancyer 版本:

$tmp = array();
$result = array();

$result = array_values(array_filter(array_map(function($innerArray)use(&$tmp){
    if(!in_array($innerArray["user_id"], $tmp)) {
        $tmp[] = $innerArray["user_id"];
        return $innerArray;
    }
}, $arr)));

print_r($result);

答案 1 :(得分:2)

如果你正在运行PHP&gt; = 5.6,那么以下内容将起作用:

$data = [
    [
      'user_id' => '3',
      'rate' => '0',
      'note' => 'a',
    ],
    [
      'user_id' => '3',
      'rate' => '2',
      'note' => 'b',
    ],
    [
      'user_id' => '4',
      'rate' => '3',
      'note' => 'c',
    ],
];

$result = array_filter(
    $data,
    function ($value, $key) use ($data) {
        return $key === array_search($value['user_id'], array_column($data,'user_id'));
    },
    ARRAY_FILTER_USE_BOTH
);
var_dump($result);

答案 2 :(得分:0)

试试这个:

$结果=阵列();

foreach($yourArray as $innerArray) {
        if(in_array($innerArray["user_id"], $result)){
            continue;
          }
            $result[] = $innerArray;
    }

    print_r($result);

答案 3 :(得分:0)

如果user_id只是一个int或一个字符串,你可以将它用作索引,如下所示:

$a = [
    [
        'id' => 1,
    ],
    [
        'id' => 2,
    ],
    [
        'id' => 3,
    ],
    [
        'id' => 1,
    ],
];

$b = array_reduce($a, function($carry, $item) {
    $carry[$item['id']] = $item;
    return $carry;
}, []);

var_dump($b);

// Or more plainly like this:
$b = [];
foreach ($a as $val) {
    $b[$val['id']] = $val;
}

var_dump($b);

// If you want numerical indexes, just do this
$b = array_values($b);

答案 4 :(得分:0)

1.你可以试试这个

$result = array_reverse(array_values(array_column(
    array_reverse($data),
    null,
    'user_id'
)));
<块引用>

返回完整数组或对象也可能为NULL(这是 与 index_key 一起用于重新索引数组)。

2.如果您使用 sql 查询获取记录,您可以使用 GROUP BY 子句,如下所示:

GROUP BY user_id    

参考:php remove duplicates from multidimensional array by value