首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >对php中数组中同名的元素进行计数

对php中数组中同名的元素进行计数
EN

Stack Overflow用户
提问于 2019-04-12 15:35:48
回答 2查看 809关注 0票数 -2

所以我有这个数组:

我不知道它是否清楚,但是在这个数组中有很多元素具有相同的名称,我想计算这些元素并显示出来,这是我创建数组的方式:

代码语言:javascript
复制
 foreach ($rowa as $rowsa)
{
    $sql = "SELECT count(*) as NUMBER FROM BANDZENDINGEN WHERE FB_AFGESLOTEN = 'F' AND FB_AKTIEF = 'T' AND FI_AFVOERKANAAL = 1 AND FI_RAYONID = $rowsa  AND FI_VERRIJKINGID < 1;";
    $sfh = $dbh->prepare($sql);
    $sfh->execute();
    $row = $sfh->fetchAll(PDO::FETCH_COLUMN, 0);

    array_push($row, $rows['FC_RAYON']);
    print_r($row);

}

我已经尝试过了:

count of duplicate elements in an array in php

这个anwser似乎不适合我,但也许我做错了什么。

顺便说一下,$rows‘’FC_RAYON‘来自另一个查询,它与这个问题无关,但如果你想看它,我会编辑我的帖子来显示它。

那么我必须这么做吗?你能帮帮我吗。

编辑

最好看看这个数组:

代码语言:javascript
复制
 Array ( [0] => 2 [1] => RT-SCB-PB01 ) 
 Array ( [0] => 0 [1] => RT-SCB-PB01 ) 
 Array ( [0] => 3 [1] => RT-SCB-PB01 ) 
 Array ( [0] => 1 [1] => ASDC-PBSN ) 
 Array ( [0] => 0 [1] => ASDC-PBSN ) 
 Array ( [0] => 0 [1] => ASDC-PBSN ) 
 Array ( [0] => 0 [1] => ASDC-PBSN ) 
 Array ( [0] => 1 [1] => ASDW-PBSN ) 

这是数组中非常小的一部分。

编辑2

代码语言:javascript
复制
 Array
(
  [0] => 2
  [1] => RT-SCB-PB01
)

 Array
(
  [0] => 2
  [1] => RT-SCB-PB01
)

Array
(
  [0] => 1
  [1] => RT-SCB-PB01
)

Array
(
  [0] => 3
  [1] => RT-SCB-PB01
)

Array
(
  [0] => 2
  [1] => ASDC-PBSN
)

Array
(
  [0] => 2
  [1] => ASDC-PBSN
)

Array
(
  [0] => 1
  [1] => ASDC-PBSN
)

Array
(
  [0] => 1
  [1] => ASDW-PBSN
)

Array
(
  [0] => 0
  [1] => ASDW-PBSN
)

Array
(
  [0] => 0
  [1] => ASDW-PBSN
)

这是一个更好的数组视图,数组中的数据是不同的,因为它是一个非常活跃的数据库

编辑3

如果你感兴趣,这是我的全部结果,你可以在这里看到它:

使用画图打开https://mega.nz/#!uvpBWSoL!V6xYCuJ5mCWwiYqnoaz6LiYynioCylWDxPYioV_9qpo

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-04-12 16:34:19

array_count_values

array_count_values()返回一个数组,使用数组的值作为键,它们在数组中的频率作为值。

代码语言:javascript
复制
$varArray = array(); // take a one empty array

foreach ($rowa as $rowsa)
{
    $sql = "SELECT count(*) as NUMBER FROM BANDZENDINGEN WHERE FB_AFGESLOTEN = 'F' AND FB_AKTIEF = 'T' AND FI_AFVOERKANAAL = 1 AND FI_RAYONID = $rowsa  AND FI_VERRIJKINGID < 1;";
    $sfh = $dbh->prepare($sql);
    $sfh->execute();
    $row = $sfh->fetchAll(PDO::FETCH_COLUMN, 0);

    array_push($row, $rows['FC_RAYON']);
    //print_r($row);
    //array_push($varArray,$rows['FC_RAYON']); // Also May I think $rows['FC_RAYON'] is give value like RT-SCB-PB01,ASDC-PBSN etc.
    array_push($varArray,$row[1]); // I have push the send value of array like RT-SCB-PB01,ASDC-PBSN etc. and make in single array.
}

$dupArrays = array_count_values($varArray); // It will return Counts all the values of an array
echo 'Total No Items: '.count($dupArrays).'<br><br>';
echo "<pre>";
print_r($dupArrays);
echo "</pre>";

输出将为:

代码语言:javascript
复制
Total No Items: 3

Array
(
    [RT-SCB-PB01] => 3 // Count of duplicate value of RT-SCB-PB01 is 3
    [ASDC-PBSN] => 4 // Count of duplicate value of ASDC-PBSN is 3
    [ASDW-PBSN] => 1 // Count of duplicate value of ASDW-PBSN is 3
)

使用foreach方法获取

代码语言:javascript
复制
foreach($dupArrays as $key => $value){
    echo $key.' Count '.$value.' times.';
    echo "<br>";
}

输出:

代码语言:javascript
复制
RT-SCB-PB01 Count 3 times.
ASDC-PBSN Count 4 times.
ASDW-PBSN Count 1 times.
票数 4
EN

Stack Overflow用户

发布于 2019-04-15 02:26:01

你就不能像这样做一个简单的查询:

代码语言:javascript
复制
$sql = "SELECT FI_RAYONID,COUNT(FI_RAYONID) as NUMBER 
    FROM BANDZENDINGEN 
    WHERE FB_AFGESLOTEN = 'F' 
    AND FB_AKTIEF = 'T' 
    AND FI_AFVOERKANAAL = 1  
    AND FI_VERRIJKINGID < 1 
    GROUP BY FI_RAYONID ;";
$sfh = $dbh->prepare($sql);
$sfh->execute();
$result = $sfh->fetch(PDO::FETCH_KEY_PAIR);

然后,$result变成一个包含id和计数的键控数组,因此您可以更简单地使用它

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55646668

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档