PHP 5.5.17 is available

count

(PHP 4, PHP 5)

countConta o número de elementos de uma variável, ou propriedades de um objeto

Descrição

int count ( mixed $var [, int $mode ] )

Conta os elementos de um array, ou propriedades em um objeto.

Para objetos, se você tem SPL instalada, você pode fazer um gancho na count() implementando a interface Countable. A interface tem exatamente um método, count(), que retorna o valor retornado para função count().

Por favor, veja a sessão Array do manual para uma explicação mais detalhada sobre como os arrays são implementados e utilizados no PHP.

Parâmetros

var

The array.

mode

Se o parâmetro opcional mode for COUNT_RECURSIVE (ou 1), a função count() irá recursivamente contar a matriz. Isto é particularmente util para contar elementos em matriz multidimensional. O valor padrão para mode é 0. count() não detecta infinita recursão.

Valor Retornado

Retorna o número de elementos em var, que normalmente é um array, pois qualquer outra coisa terá somente um elemento.

Se var não for um array ou um objeto, com a interface Countable implementada, 1 será retornado. Há uma exceção, se var é NULL, 0 é retornado.

Cuidado

count() pode retornar 0 para uma variável que não existe, mas também pode retornar 0 para uma variável que tenha sido inicializada como um array vazio. Use isset() para checar se a variável existe.

Changelog

Versão Descrição
4.2.0 O parâmetro opcional mode foi adicionado.

Exemplos

Exemplo #1 Exemplo da função count()

<?php
$a
[0] = 1;
$a[1] = 3;
$a[2] = 5;
$result count($a);
// $result == 3

$b[0] = 7;
$b[5] = 9;
$b[10] = 11;
$result count($b);
// $result == 3

$result count(null);
// $result == 0

$result count(false);
// $result == 1
?>

Exemplo #2 Uso recursivo da função count()

<?php
$comidas 
= array('frutas'  => array('laranja''banana''maçã'),
'veggie'  => array('cenoura''couve','ervilha'));
// contagem recursiva
echo count($comidasCOUNT_RECURSIVE);  // mostra 8
// contagem normal
echo count($comidas);                   // mostra 2
?>

Veja Também

  • is_array() - Verifica se a variável é um array
  • isset() - Informa se a variável foi iniciada
  • strlen() - Retorna o tamanho de uma string

add a note add a note

User Contributed Notes 13 notes

up
28
alexandr at vladykin dot pp dot ru
7 years ago
My function returns the number of elements in array for multidimensional arrays subject to depth of array. (Almost COUNT_RECURSIVE, but you can point on which depth you want to plunge).

<?php
 
function getArrCount ($arr, $depth=1) {
      if (!
is_array($arr) || !$depth) return 0;
        
    
$res=count($arr);
        
      foreach (
$arr as $in_ar)
        
$res+=getArrCount($in_ar, $depth-1);
     
      return
$res;
  }
?>
up
14
danny at dannymendel dot com
7 years ago
I actually find the following function more useful when it comes to multidimension arrays when you do not want all levels of the array tree.

// $limit is set to the number of recursions
<?php
function count_recursive ($array, $limit) {
   
$count = 0;
    foreach (
$array as $id => $_array) {
        if (
is_array ($_array) && $limit > 0) {
           
$count += count_recursive ($_array, $limit - 1);
        } else {
           
$count += 1;
        }
    }
    return
$count;
}
?>
up
1
Gerd Christian Kunze
9 months ago
Get maxWidth and maxHeight of a two dimensional array..?

Note:
1st dimension = Y (height)
2nd dimension = X (width)
e.g. rows and cols in database result arrays

<?php
$TwoDimensionalArray
= array( 0 => array( 'key' => 'value', ...), ... );
?>

So for Y (maxHeight)
<?php
$maxHeight
= count( $TwoDimensionalArray )
?>

And for X (maxWidth)
<?php
$maxWidth
= max( array_map( 'count'$TwoDimensionalArray ) );
?>

Simple? ;-)
up
0
onlyranga at gmail dot com
4 months ago
If you want to run through large arrays don't use count() function in the loops , its a over head in performance,  copy the count() value into a variable and use that value in loops for a better performance.

Eg:

// Bad approach

for($i=0;$i<count($some_arr);$i++)
{
    // calculations
}

// Good approach

$arr_length = count($some_arr);
for($i=0;$i<$arr_length;$i++)
{
    // calculations
}
up
-4
atoi_monte at hotmail dot com
7 years ago
Please note: While SPL is compiled into PHP by default starting with PHP 5, the Countable interface is not available until 5.1
up
-3
MaxTheDragon at home dot nl
10 months ago
If you wish to test if an array contains any elements (or is empty), you might tempted to use count to do something like this:

<?php
if (count($my_array) > 0) {
// array is not empty...
}

// or this ...

if (count($my_array) === 0) {
// array is empty...
}
?>

Using the count function here is totally unnecessary and slower.

Instead, you should rely on the fact that empty arrays evaluate to false when cast to a boolean:

<?php
$hasElements
= (boolean) $my_array;

// or ...

$isEmpty = !$my_array;

// or in a conditional statement...

if ($my_array) {
// array is not empty...
}
?>

Only use count if you need to know if an array contains a specific number of elements n (where n > 0).
up
-7
semmelbroesel at gmail dot com
1 year ago
I've read this somewhere else before, but experienced it first hand now, so I thought I'd post it here.

While in regular use, count() is pretty fast, this changes rapidly when used in a for loop. Example:

for ($x = 0; $x < count($array); $x++)
{
  // some code here
}

If your array contains a lot of data, this code gets slowed down significantly. Better way to write this:

$arrayCount = count($array);
for ($x = 0; $x < $arrayCount; $x++)
{
  // some code here
}

I didn't think it would make such a difference, but it did in my case - changed 15 seconds load time into 1 second!
up
-9
jezdec at email dot cz
5 years ago
Hi there,
there is a simple script with example for counting rows and columns of a two-dimensional array.

<?php
$data
= array(
   
"apples" =>
        array(
"red", "yellow", "pineapples"),
   
"bananas" =>
        array(
"small", "medium", "big"),
   
"vegs" =>
        array(
"potatoes", "carrots", "onions")
);

$rows = count($data,0);
$cols = (count($data,1)/count($data,0))-1;
print
"There are {$rows} rows and {$cols} columns in the table!";
?>
up
-7
lopezvit at gmail dot com
11 months ago
I think that maybe that is faster (I don't know why, because, at least in C, for loops are faster than while ones due to compile optimization) but what is sure is that, in case the list is empty, you are going to iterate over the loop at least one. And I'm sure that is not what you want to do. The correct way in this occassion is to use a normal while, not a do, while.
up
-4
norbyte
6 months ago
If you want to check whether large arrays contain a specific (less) number of array elements, don't use count(). This is very slow because each element has to get iterated.

This is much faster:

function isArrayCount(array $array, $count) {
    $count = (int) $count;
    $result = reset($array);
    if ($count === 0) {
        // for empty arrays reset returns FALSE
        // we have to switch the boolean result
        $result = !$result;
    }
    for($i = 1; $i < $count; $i++) {
        if (next($array) === FALSE) {
            $result = FALSE;
            break;
        }
    }
    return $result;
}
up
-23
freefaler at gmail dot com
9 years ago
If you want to count only elements in the second level of 2D arrays.A close to mind note, useful for multidimentional arrays:

<?php
$food
= array('fruits' => array('orange', 'banana', 'apple'),
            
'veggie' => array('carrot', 'collard','pea'));

// recursive count
echo count($food,COUNT_RECURSIVE);  // output 8

// normal count
echo count($food);                  // output 2

// all the fruits and veggies
echo (count($food,COUNT_RECURSIVE)-count($food,0)); //output 6
?>
up
-26
nicolas dot grekas+php at gmail dot com
3 years ago
As of PHP 5.2.6, count() DOES detect infinite recursion.
It triggers a warning when its argument is a recursive array.
up
-31
me at me dot com
1 year ago
To the poster above, the fastest way is to use 'do/while'. Try this way, you will find it faster than 'for'.
$arrayCount = count($array);
do{
    // some code here
    --$arrayCount;
}
while($arrayCount > 0);
To Top