59

我想计算数组中每个重复项的出现次数,并最终得到一个只有唯一/非重复项及其各自出现的数组。

这是我的代码;但我不知道哪里出错了!

<?php
$array = array(12,43,66,21,56,43,43,78,78,100,43,43,43,21);

//$previous[value][Occurrence]

for($arr = 0; $arr < count($array); $arr++){

    $current = $array[$arr];
    for($n = 0; $n < count($previous); $n++){
        if($current != $previous[$n][0]){// 12 is not 43 -----> TRUE
            if($current != $previous[count($previous)][0]){
                $previous[$n++][0] = $current;
                $previous[$n++][1] = $counter++;
            }
        }else{  
            $previous[$n][1] = $counter++;
            unset($previous[count($previous)-1][0]);
            unset($previous[count($previous)-1][1]);
        }   
    }
}
//EXPECTED VALUES
echo 'No. of NON Duplicate Items: '.count($previous).'<br><br>';// 7
print_r($previous);// array( {12,1} , {21,2} , {43,6} , {66,1} , {56,1} , {78,2} , {100,1})
?>    
4

13 回答 13

172

array_count_values, 请享用 :-)

$array = array(12,43,66,21,56,43,43,78,78,100,43,43,43,21);
$vals = array_count_values($array);
echo 'No. of NON Duplicate Items: '.count($vals).'<br><br>';
print_r($vals);

结果:

No. of NON Duplicate Items: 7
Array
(
    [12] => 1
    [43] => 6
    [66] => 1
    [21] => 2
    [56] => 1
    [78] => 2
    [100] => 1
)
于 2012-11-29T20:17:37.407 回答
10

如果你想在没有的情况下尝试,'array_count_values' 你可以在这里用一种聪明的方式来做

<?php
$input= array(12,43,66,21,56,43,43,78,78,100,43,43,43,21);

$count_values = array();
foreach ($input as $a) {

     @$count_values[$a]++;

}
echo 'Duplicates count: '.count($count_values);
print_r($count_values);
?>
于 2015-03-14T07:05:24.957 回答
4

如果你有一个多维数组,你可以在 PHP 5.5+ 上使用:

array_count_values(array_column($array, 'key'))

返回例如

 [
   'keyA' => 4,
   'keyB' => 2,
 ]
于 2018-05-27T21:05:09.823 回答
3

实际上,我最近编写了一个函数来检查数组中的子字符串,在这种情况下会派上用场。

function strInArray($haystack, $needle) {
    $i = 0;
    foreach ($haystack as $value) {
        $result = stripos($value,$needle);
        if ($result !== FALSE) return TRUE;
        $i++;
    }
    return FALSE;
}

$array = array(12,43,66,21,56,43,43,78,78,100,43,43,43,21);

for ($i = 0; $i < count($array); $i++) {
    if (strInArray($array,$array[$i])) {
        unset($array[$i]);
    }
}
var_dump($array);
于 2012-11-29T20:22:46.000 回答
2

您可以使用 foreach 循环来完成。

          $arrayVal = array(1,2,3,1,2,3,1,2,3,4,4,5,6,4,5,6,88);
          $set_array = array();
          foreach ($array as $value) {
            $set_array[$value]++;
          }
           print_r($set_array);

输出 :-

  Array( [1] => 3
             [2] => 3
             [3] => 3
             [4] => 3
             [5] => 2
             [6] => 2
             [88] => 1
            )
于 2018-07-09T09:46:07.540 回答
2

在不使用内置函数的情况下计算 PHP 中数组的重复元素

$arraychars=array("or","red","yellow","green","red","yellow","yellow");
$arrCount=array();
        for($i=0;$i<$arrlength-1;$i++)
        {
          $key=$arraychars[$i];
          if($arrCount[$key]>=1)
            {
              $arrCount[$key]++;
            } else{
              $arrCount[$key]=1;
        }
        echo $arraychars[$i]."<br>";
     }
        echo "<pre>";
        print_r($arrCount);
于 2018-03-20T13:50:20.147 回答
1

PHP 为您提供了一个名为in_array()的神奇函数。

使用您的部分代码,我们将修改循环如下:

<?php
$array = array(12,43,66,21,56,43,43,78,78,100,43,43,43,21);
$arr2 = array();
$counter = 0;
for($arr = 0; $arr < count($array); $arr++){
    if (in_array($array[$arr], $arr2)) {
        ++$counter;
        continue;
    }
    else{
        $arr2[] = $array[$arr];
    }
}
echo 'number of duplicates: '.$counter;
print_r($arr2);
?>

上面的代码片段将返回重复项的总数,即从样本数组中,43 重复 5 次,78 重复 1 次,21 重复 1 次,然后返回一个不重复的数组。

于 2012-11-29T20:29:04.973 回答
1

您也可以将它与文本项数组一起使用,您将正确获得重复的数量,但 PHP 显示

警告:array_count_values():只能计算 STRING 和 INTEGER 值!

$domains = 
array (
  0 => 'i1.wp.com',
  1 => 'i1.wp.com',
  2 => 'i2.wp.com',
  3 => 'i0.wp.com',
  4 => 'i2.wp.com',
  5 => 'i2.wp.com',
  6 => 'i0.wp.com',
  7 => 'i2.wp.com',
  8 => 'i0.wp.com',
  9 => 'i0.wp.com' );

$tmp = array_count_values($domains);
print_r ($tmp);

    array (
      'i1.wp.com' => 2730,
      'i2.wp.com' => 2861,
      'i0.wp.com' => 2807
    )
于 2017-08-14T20:20:58.030 回答
1

最简单的解决方案(这就是 PHP 摇滚的地方) -仅重复

$r = array_filter(array_count_values($array), function($v) { return $v > 1; });

并检查:

print_r($r);

结果$r

[43] => 6
[21] => 2
[78] => 2
于 2021-11-04T13:30:09.720 回答
0

此代码将在同一数组中返回重复值

$array = array(12,43,66,21,56,43,43,78,78,100,43,43,43,21);
foreach($arr as $key=>$item){
  if(array_count_values($arr)[$item] > 1){
     echo "Found Matched value : ".$item." <br />";
  }
}
于 2019-01-31T08:37:06.827 回答
0

我从谷歌来到这里,寻找一种方法来计算数组中重复项的出现。这是简单的方法:

$colors = array("red", "green", "blue", "red", "yellow", "blue");
$unique_colors = array_unique($colors);
// $unique colors : array("red", "green", "blue", "yellow")
$duplicates = count($colors) - count($unique_colors);
// $duplicates = 6 - 4 = 2
if( $duplicates == 0 ){
 echo "There are no duplicates";
}
echo "No. of Duplicates are :" . $duplicates;

// Output: No. of Duplicates are: 2

array_unique() 如何工作?

它包含所有重复项。 例如: 假设我们有一个数组如下 -

$cars = array( [0]=>"lambo", [1]=>"ferrari", [2]=>"Lotus", [3]=>"ferrari", [4]=>"Bugatti");

当您这样做时,$cars = array_unique($cars); 汽车将只有以下元素。 $cars = array( [0]=>"lambo", [1]=>"ferrari", [2]=>"Lotus", [4]=>"Bugatti");

阅读更多:https ://www.w3schools.com/php/func_array_unique.asp

希望它对那些从谷歌来到这里寻找一种计算数组中重复值的方法的人有所帮助。

于 2017-03-08T07:13:05.463 回答
-1
$search_string = 4;
$original_array = [1,2,1,3,2,4,4,4,4,4,10];
$step1 = implode(",", $original_array); // convert original_array to string
$step2 = explode($search_string, $step1); // break step1 string into a new array using the search string as delimiter
$result = count($step2)-1; // count the number of elements in the resulting array, minus the first empty element
print_r($result); // result is 5
于 2020-01-29T14:20:36.137 回答
-2
    $input = [1,2,1,3,2,4,10];
    //if give string
    //$input = "hello hello how are you how hello";
    //$array = explode(' ',$input);
    $count_val = [];
    foreach($array as $val){
      $count_val[$val]++;
    }
    print_r($count_val);
//output ( [1] => 2 [2] => 2 [3] => 1 [4] => 1 [10] => 1 )
于 2019-08-13T19:07:52.540 回答