array_slice

(PHP 4, PHP 5, PHP 7, PHP 8)

array_sliceExtrai uma parcela de um array

Descrição

array_slice(
    array$array,
    int$offset,
    ?int$length = null,
    bool$preserve_keys = false
): array

array_slice() retorna a sequência de elementos de um array delimitado pelos parâmetros offset e length.

Parâmetros

array

O array de entrada.

offset

Se offset for não negativo, a sequência iniciará no início do array.

Se offset for negativo, a sequência iniciará a partir do fim do array.

Nota:

O parâmetro offset denota uma posição dentro do array, não das chaves.

length

Se length for positivo, então a sequência terá até essa quantidade de elementos.

Se o array for mais curto que length, então somente os elementos presentes serão retornados.

Se length for negativo então a sequência conterá até essa quantidade de elementos do final do array.

Se esse parâmetro for omitido, a sequência conterá todos os elementos a partir de offset até o final do array.

preserve_keys

Nota:

array_slice() não irá reordenar ou resetar os índices inteiros do array por padrão. Este comportamento pode ser alterado ao informar preserve_keys para true. Chaves string são sempre preservados, independente do parâmetro.

Valor Retornado

Retorna a parcela. Se o offset for maior que o tamanho do array, um array vazio é retornado.

Exemplos

Exemplo #1 Exemplos de array_slice()

<?php
$input
= array("a", "b", "c", "d", "e");

$output = array_slice($input, 2); // retorna "c", "d", e "e"
$output = array_slice($input, -2, 1); // retorna "d"
$output = array_slice($input, 0, 3); // retorna "a", "b", e "c"

// Obverse as diferenças nas chaves retornadas
print_r(array_slice($input, 2, -1));
print_r(array_slice($input, 2, -1, true));
?>

O exemplo acima produzirá:

Array ( [0] => c [1] => d ) Array ( [2] => c [3] => d )

Exemplo #2 array_slice() e arrays baseados em 1

<?php
$input
= array(1 => "a", "b", "c", "d", "e");
print_r(array_slice($input, 1, 2));
?>

O exemplo acima produzirá:

Array ( [0] => b [1] => c )

Exemplo #3 array_slice() com chaves mistas

<?php
$ar
= array('a'=>'apple', 'b'=>'banana', '42'=>'pear', 'd'=>'orange');
print_r(array_slice($ar, 0, 3));
print_r(array_slice($ar, 0, 3, true));
?>

O exemplo acima produzirá:

Array ( [a] => apple [b] => banana [0] => pear ) Array ( [a] => apple [b] => banana [42] => pear )

Veja Também

To Top