31

我在溢出和谷歌上做了很多环顾四周,但没有一个结果适用于我的具体情况。

我有一个名为 $holder 的占位符数组,值如下:

    Array ( 
    [0] => Array ( 
        [id] => 1 
        [pid] => 121 
        [uuid] => 1  
        )
    [1] => Array ( 
        [id] => 2 
        [pid] => 13
        [uuid] => 1
        )
    [2] => Array ( 
        [id] => 5 
        [pid] => 121 
        [uuid] => 1
        )
    ) 

我试图从这个多维数组中提取不同/唯一的值。我想要的最终结果是一个包含 (13,121) 的变量,或者(最好)一个数组,如下所示: Array( [0] => 13 [1] => 121 )

我再次尝试了序列化等,但不太明白在每个数组中使用单个键操作时它是如何工作的。

我尽量说清楚。我希望这是有道理的...

4

8 回答 8

70

看起来很简单:将所有pid值提取到他们自己的数组中,运行它array_unique

$uniquePids = array_unique(array_map(function ($i) { return $i['pid']; }, $holder));

同样的事情:

$pids = array();
foreach ($holder as $h) {
    $pids[] = $h['pid'];
}
$uniquePids = array_unique($pids);
于 2012-05-02T06:06:22.007 回答
41

在 php >= 5.5 中,您可以使用array_column

array_unique(array_column($holder, 'pid'));
于 2015-05-25T14:48:25.383 回答
4

试试这个

foreach($arr as $key => $val) {
    $new_arr[] = $val['pid'];
}
$uniq_arr = array_unique($new_arr);
于 2012-05-02T06:08:11.900 回答
4

只需对其进行迭代并array_unique在结果上应用:

foreach($holder as $yourValues){
    $pids[] = $yourValues['pid'];
}
$yourUniquePids = array_unique($pids);
于 2012-05-02T06:08:24.943 回答
4

假设您的数组称为 $holder:

$unique = array();
foreach( $holder as $h )
    if( ! in_array($h, $unique ) )
        $unique[] = $h;

我相信,这是一种比通过 array_unique 更有效的方法。可能是一样的。

于 2015-02-11T23:43:30.727 回答
1
$uniquearray = [];
    for($i=0;$i<count($assocarray);$i++){
        if(!in_array($assocarray[$i]['KEY'],$uniquearray)){
            $uniquearray[$i]= $assocarray[$i]['KEY'];
        }
}
于 2020-02-03T13:25:37.027 回答
0

嗨,请尝试下面给出的代码以获取唯一值,然后对该值进行排序

<?php

$sort_arr = unique_sort($holder, 'pid');
echo "<pre>";
print_r($sort_arr);
echo"</pre>";

/*function for get unique value then sort them*/

function unique_sort($arrs, $id) {
    $unique_arr = array();
    foreach ($arrs AS $arr) {

        if (!in_array($arr[$id], $unique_arr)) {
            $unique_arr[] = $arr[$id];
        }
    }
    sort($unique_arr);
    return $unique_arr;
}

谢谢

于 2012-05-02T06:30:04.183 回答
-1

对于我的情况,我使用这种方法

//get some data from db to array
while ($row = mysqli_fetch_assoc($query)){
   $data[] = $row;
}

//display unique value
echo "<table>";
$uniq = array();
foreach ($data as $row) {
    if(!in_array($row['path'], $uniq)) {
        $uniq[] = $row['path'];
        echo "<tr>";
        echo "<td>";
        echo $row['path'];
        echo "</td>";
        echo "<td>";
        echo $row['relationship_id'];
        echo "</td>";
        echo "</tr>";
    }
}
echo "</table>";
于 2016-12-30T09:11:45.140 回答