International PHP Conference 2015

Funkcje Tablic

Zobacz też:

Patrz także: is_array(), explode(), implode(), split(), preg_split(), i unset().

Spis treści

  • array_change_key_case — Zwraca tablicę ze wszystkimi kluczami tekstowymi zamienionymi na wyłącznie małe lub wyłącznie duże litery
  • array_chunk — Podziel tablicę na kawałki
  • array_combine — Tworzy tablicę używając wartości jednej tablicy jako kluczy a drugiej jako wartości
  • array_count_values — Zlicza wszystkie wartości w tablicy
  • array_diff_assoc — Oblicza różnicę między tablicami z dodatkowym sprawdzaniem kluczy
  • array_diff_key — Oblicza różnicę tablic używając kluczy do porównań
  • array_diff_uassoc — Computes the difference of arrays with additional index check which is performed by a user supplied callback function
  • array_diff_ukey — Oblicza różnicę tablic używając funkcji zwrotnej do porównywania kluczy
  • array_diff — Zwraca różnice pomiędzy tablicami
  • array_fill_keys — Fill an array with values, specifying keys
  • array_fill — Wypełnij tablicę podanymi wartościami
  • array_filter — Filtruje elementy przy użyciu funkcji zwrotnej
  • array_flip — Wymienia wszystkie klucze z przypisanymi do nich wartościami w tablicy
  • array_intersect_assoc — Wylicza przecięcie tablic z dodatkowym sprawdzaniem indeksów
  • array_intersect_key — Computes the intersection of arrays using keys for comparison
  • array_intersect_uassoc — Computes the intersection of arrays with additional index check, compares indexes by a callback function
  • array_intersect_ukey — Computes the intersection of arrays using a callback function on the keys for comparison
  • array_intersect — Zwraca przecięcie tablic
  • array_key_exists — Sprawdza czy podany klucz lub indeks istnieje w tablicy
  • array_keys — Zwraca wszystkie klucze z tablicy
  • array_map — Wykonuje funkcję zwrotną na elementach podanej tablicy
  • array_merge_recursive — Łączy dwie lub więcej tablic rekurencyjnie
  • array_merge — Łączy jedną lub więcej tablic
  • array_multisort — Sortuje wiele tablic lub wielowymiarowe tablice
  • array_pad — Dopełnij tablicę do podanej długości podanymi wartościami
  • array_pop — Zdejmij element z końca tablicy
  • array_product — Calculate the product of values in an array
  • array_push — Wstaw jeden lub więcej elementów na koniec tablicy
  • array_rand — Wybierz jeden lub więcej losowych elementów z tablicy
  • array_reduce — Iteracyjnie zredukuj tablicę do pojedyńczej wartości używając funkcji zwrotnej
  • array_replace_recursive — Replaces elements from passed arrays into the first array recursively
  • array_replace — Replaces elements from passed arrays into the first array
  • array_reverse — Zwraca tablicę z elementami ustawionymi w porządku odwrotnym
  • array_search — Przeszukuje tablicę pod kątem podanej wartości i w przypadku sukcesu zwraca odpowiedni klucz
  • array_shift — Usuń element z początku tablicy
  • array_slice — Wytnij kawałek tablicy
  • array_splice — Usuń część tablicy i zamień ją na coś innego
  • array_sum — Oblicza sumę wartości w tablicy
  • array_udiff_assoc — Computes the difference of arrays with additional index check, compares data by a callback function
  • array_udiff_uassoc — Computes the difference of arrays with additional index check, compares data and indexes by a callback function
  • array_udiff — Computes the difference of arrays by using a callback function for data comparison
  • array_uintersect_assoc — Oblicza przecięcie tablic z dodatkowym sprawdzaniem indeksów, porównując dane przez funkcję zwrotną
  • array_uintersect_uassoc — Computes the intersection of arrays with additional index check, compares data and indexes by a callback functions
  • array_uintersect — Computes the intersection of arrays, compares data by a callback function
  • array_unique — Usuwa duplikaty wartości z tablicy
  • array_unshift — Wstaw jeden lub więcej elementów na początek tablicy
  • array_values — Zwraca wszystkie wartości z tablicy
  • array_walk_recursive — Apply a user function recursively to every member of an array
  • array_walk — Zastosuj funkcję użytkownika do każdego elementu tablicy
  • array — Stwórz tablicę
  • arsort — Sortuje tablicę w porządku odwrotnym z zachowaniem skojarzenia kluczy
  • asort — Posortuj tablicę zachowując skojarzenia kluczy
  • compact — Stwórz tablicę zawierającą zmienne i ich wartości
  • count — Zlicza ilość elementów w tablicy lub pól obiektu
  • current — Zwraca bieżący element tablicy
  • each — Zwraca bieżącą parę klucza i wartości z tablicy i przesuwa kursor tablicy
  • end — Ustawia wewnętrzny wskaźnik tablicy na ostatnim elemencie
  • extract — Importuj zmienne do bieżącej tablicy symboli z tablicy
  • in_array — Sprawdza czy wartość istnieje w tablicy
  • key — Pobiera klucz z tablicy asocjacyjnej
  • krsort — Sortuj tablicę według kluczy w porządku odwrotnym
  • ksort — Sortuj tablicę według klucza
  • list — Przypisz zmienne tak jakby były tablicą
  • natcasesort — Sortuj tablicę używając algorytmu "porządek naturalny" ignorującego wielkość znaków
  • natsort — Sortuj tablicę używając algortmu "porządek naturalny"
  • next — Przesuń do przodu wewnętrzny wskaźnik tablicy
  • pos — Alias dla current
  • prev — Cofnij wewnętrzny wskaźnik tablicy
  • range — Stwórz tablicę zawierającą przedział elementów
  • reset — Ustaw wewnętrzny wskaźnik tablicy na jej pierwszy element
  • rsort — Sortuj tablicę w porządku odwrotnym
  • shuffle — Przetasuj tablicę
  • sizeof — Alias dla count
  • sort — Sortuje tablicę
  • uasort — Sortuj tablicę korzystając ze zdefiniowanej przez użytkownika funkcji porównującej i zachowując skojarzenia kluczy
  • uksort — Sortuj tablicę według kluczy korzystając ze zdefiniowanej przez użytkownika funkcji porównującej
  • usort — Sortuje tablicę według wartości korzystając ze zdefiniowanej przez użytkownika funkcji porównującej
add a note add a note

User Contributed Notes 11 notes

kolkabes at googlemail dot com
3 years ago
Short function for making a recursive array copy while cloning objects on the way.

function arrayCopy( array $array ) {
$result = array();
$array as $key => $val ) {
is_array( $val ) ) {
$result[$key] = arrayCopy( $val );
            } elseif (
is_object( $val ) ) {
$result[$key] = clone $val;
            } else {
$result[$key] = $val;
renatonascto at gmail dot com
6 years ago
Big arrays use a lot of memory possibly resulting in memory limit errors. You can reduce memory usage on your script by destroying them as soon as you´re done with them. I was able to get over a few megabytes of memory by simply destroying some variables I didn´t use anymore.
You can view the memory usage/gain by using the funcion memory_get_usage(). Hope this helps!
seva dot lapsha at gmail dot com
6 years ago
Arrays are good, but inapplicable when dealing with huge amounts of data.

I'm working on rewriting some array functions to operate with plain Iterators - map, reduce, walk, flip et cetera are already there.

In addition I'm going to implement simulation of comprehensions (generators) in PHP (

See the source code, examples and documentation at
dave at davidhbrown dot us
3 years ago
While PHP has well over three-score array functions, array_rotate is strangely missing as of PHP 5.3. Searching online offered several solutions, but the ones I found have defects such as inefficiently looping through the array or ignoring keys.

The following array_rotate() function uses array_merge and array_shift to reliably rotate an array forwards or backwards, preserving keys. If you know you can trust your $array to be an array and $shift to be between 0 and the length of your array, you can skip the function definition and use just the return expression in your code.

function array_rotate($array, $shift) {
is_array($array) || !is_numeric($shift)) {
is_array($array)) error_log(__FUNCTION__.' expects first argument to be array; '.gettype($array).' received.');
is_numeric($shift)) error_log(__FUNCTION__.' expects second argument to be numeric; '.gettype($shift)." `$shift` received.");
$shift %= count($array); //we won't try to shift more than one array length
if($shift < 0) $shift += count($array);//handle negative shifts as positive
return array_merge(array_slice($array, $shift, NULL, true), array_slice($array, 0, $shift, true));
A few simple tests:

print_r(array_rotate($array, 2));
print_r(array_rotate($array, -2));
print_r(array_rotate($array, count($array)));
print_r(array_rotate($array, "4"));
print_r(array_rotate($array, -9));
mo dot longman at gmail dot com
8 years ago
to 2g4wx3:
i think better way for this is using JSON, if you have such module in your PHP. See

to convert JS array to JSON string: arr.toJSONString();
to convert JSON string to PHP array: json_decode($jsonString);

You can also stringify objects, numbers, etc.
callmeanaguma at gmail dot com
2 years ago
If you need to flattern two-dismensional array with single values assoc subarrays, you could use this function:

function arrayFlatten($array) {
$flattern = array();
        foreach (
$array as $key => $value){
$new_key = array_keys($value);
$flattern[] = $value[$new_key[0]];
ob at babcom dot biz
9 years ago
Here is a function to find out the maximum depth of a multidimensional array.

// return depth of given array
// if Array is a string ArrayDepth() will return 0
// usage: int ArrayDepth(array Array)

function ArrayDepth($Array,$DepthCount=-1,$DepthArray=array()) {
  if (
    foreach (
$Array as $Key => $Value)
$DepthArray as $Value)
cyberchrist at futura dot net
7 years ago
Lately, dealing with databases, I've been finding myself needing to know if one array, $a, is a proper subset of $b.

Mathematically, this is asking (in set theory) [excuse the use of u and n instead of proper Unicode):

( A u B ) n ( ~ B )

What this does is it first limits to known values, then looks for anything outside of B but in the union of A and B (which would be those things in A which are not also in B).

If any value exists in this set, then A is NOT a proper subset of B, because a value exists in A but not in B.  For A to be a proper subset, all values in A must be in B.

I'm sure this could easily be done any number of ways but this seems to work for me.  It's not got a lot of error detection such as sterilizing inputs or checking input types.

// bool array_subset( array, array )
// Returns true if $a is a proper subset of $b, returns false otherwise.

function array_subset( $a, $b )
    if( count( array_diff( array_merge($a,$b), $b)) == 0 )
        return true;
        return false;
rune at zedeler dot dk
8 years ago
Notice that keys are considered equal if they are "=="-equal. That is:

= array();
$a[1] = 'this is the first value';
$a[true] = 'this value overrides the first value';
$a['1'] = 'so does this one';
oliverSPAMMENOT at e-geek dot com dot au
5 years ago
Function to pretty print arrays and objects. Detects object recursion and allows setting a maximum depth. Based on arraytostring and u_print_r from the print_r function notes. Should be called like so:

($value)   //no max depth, or
egvaluetostring($value, $max_depth)   //max depth set

function egvaluetostring($value, $max_depth, $key = NULL, $depth = 0, $refChain = array()) {
$depth > 0)
$tab = str_repeat("\t", $depth);
$text .= $tab . ($key !== NULL ? $key . " => " : "");
  if (
is_array($value) || is_object($value)) {
$recursion = FALSE;
    if (
is_object($value)) {
      foreach (
$refChain as $refVal) {
        if (
$refVal === $value) {
$recursion = TRUE;
array_push($refChain, $value);
$text .= (is_array($value) ? "array" : "object") . " ( ";
    if (
$recursion) {
$text .= "*RECURSION* ";
    elseif (isset(
$max_depth) && $depth >= $max_depth) {
$text .= "*MAX DEPTH REACHED* ";
    else {
      if (!empty(
$value)) {
$text .= "\n";
        foreach (
$value as $child_key => $child_value) {
$text .= egvaluetostring($child_value, $max_depth, (is_array($value) ? "[" : "") . $child_key . (is_array($value) ? "]" : ""), $depth+1, $refChain) . ",\n";
$text .= "\n" . $tab;
$text .= ")";
    if (
is_object($value)) {
  else {
$text .= "$value";

Jck_true (leave out the &#39;_&#39; at gmail dot com)
7 years ago
A usefull function that returns a flat array.
I use it in a template system. Let the user pass a multidimensional array. Convert it using my function. Then use
= flatten($array,'','{$','}','->');
* Flattens out an multidimension array
* Using the last parameters you can define the new key based on the old path.
* @param array $array A multidimension array
* @param string $prefix Internal perfix parameter - leave empty.
* @param string $start_string What string should start the final array key?
* @param string $end_string What string should end the final array key?
* @param string $seperator The string that should seperate the piecies in final array key path
* @return array Returns the flat array
function flatten($array, $start_string= '{$',$end_string= '}',$seperator='->',$prefix="") {
$return = array();
$array as $key=>$value) {
    if (
is_array($value)) {
$return = array_merge($return, Parser_method_replace::flatten($value, $prefix.$key.$seperator,$start_string,$end_string,$seperator));
    } else
$return [$start_string.$prefix.$key.$end_string] = $value;
$template = 'My string with replacement {$test->subkey}';
{$test->subkey} will get replaced with $array['test']['subkey']
To Top