array_slice
Description
The array_slice of Array for PHP extracts a slice of the array.
Syntax
array_slice( array $array, int $offset, ?int $length = null, bool $preserve_keys = false ): array
Parameters
array
The input array.
offset
If offset is non-negative, the sequence will start at that offset in the array.
If offset is negative, the sequence will start that far from the end of the array.
length
If length is omitted, then the sequence will have everything from offset up until the end of the array.
If length is positive, then the sequence will have up to that many elements in it.
If length is negative, then the sequence will stop that many elements from the end of the array.
If length is longer than the array, then only the available array elements will be present.
preserve_keys
Default is false which will reindex the slice numerically. Keys will be preserved when set to true. String keys are always preserved.
Return
Returns the slice. If the offset is larger than the size of the array, an empty array is returned.
Examples
1 · array offset · negative
<? $array = [ "a", "b", "c", "d", "e", "f" ]; $offset = -2; $return = array_slice($array, $offset); print_r($return);
Array ( [0] => e [1] => f )
2 · array offset · zero
<? $array = [ "a", "b", "c", "d", "e", "f" ]; $offset = 0; $return = array_slice($array, $offset); print_r($return);
Array ( [0] => a [1] => b [2] => c [3] => d [4] => e [5] => f )
3 · array offset · positive
<? $array = [ "a", "b", "c", "d", "e", "f" ]; $offset = 2; $return = array_slice($array, $offset); print_r($return);
Array ( [0] => c [1] => d [2] => e [3] => f )
4 · length · negative
<? $array = [ "a", "b", "c", "d", "e", "f" ]; $offset = 0; $length = -2; $return = array_slice($array, $offset, $length); print_r($return);
Array ( [0] => a [1] => b [2] => c [3] => d )
5 · length · zero
<? $array = [ "a", "b", "c", "d", "e", "f" ]; $offset = 0; $length = 0; $return = array_slice($array, $offset, $length); print_r($return);
Array ( )
6 · length · positive
<? $array = [ "a", "b", "c", "d", "e", "f" ]; $offset = 0; $length = 2; $return = array_slice($array, $offset, $length); print_r($return);
Array ( [0] => a [1] => b )
7 · length > array
<? $array = [ "a", "b", "c", "d", "e", "f" ]; $offset = 0; $length = 100; $return = array_slice($array, $offset, $length); print_r($return);
Array ( [0] => a [1] => b [2] => c [3] => d [4] => e [5] => f )
8 · preserve_keys · false
<? $array = [ "a", "b", "c" => "c", "d", "e", "f" ]; $offset = 1; $length = 3; $preserve_keys = false; $return = array_slice($array, $offset, $length, $preserve_keys); print_r($return);
Array ( [0] => b [c] => c [1] => d )
9 · preserve_keys · true
<? $array = [ "a", "b", "c" => "c", "d", "e", "f" ]; $offset = 1; $length = 3; $preserve_keys = true; $return = array_slice($array, $offset, $length, $preserve_keys); print_r($return);
Array ( [1] => b [c] => c [2] => d )
Links
Related
Array
- array
- array_all
- array_any
- array_change_key_case
- array_chunk
- array_column
- array_combine
- array_count_values
- array_diff
- array_diff_assoc
- array_diff_key
- array_diff_uassoc
- array_diff_ukey
- array_fill
- array_fill_keys
- array_filter
- array_find
- array_find_key
- array_flip
- array_intersect
- array_intersect_assoc
- array_intersect_key
- array_intersect_uassoc
- array_intersect_ukey
- array_key_exists
- array_key_first
- array_key_last
- array_keys
- array_map
- array_merge
- array_merge_recursive
- array_multisort
- array_pad
- array_pop
- array_product
- array_push
- array_rand
- array_reduce
- array_replace
- array_replace_recursive
- array_reverse
- array_search
- array_shift
- array_splice
- array_sum
- array_udiff
- array_udiff_assoc
- array_udiff_uassoc
- array_uintersect
- array_uintersect_assoc
- array_uintersect_uassoc
- array_unique
- array_unshift
- array_values
- array_walk
- array_walk_recursive
- arsort
- asort
- compact
- count
- current
- end
- extract
- in_array
- key
- key_exists
- krsort
- ksort
- list
- natcasesort
- natsort
- next
- pos
- prev
- range
- reset
- rsort
- shuffle
- sizeof
- sort
- uasort
- uksort
- usort