Dizi İşlevleri

Ayrıca Bakınız

Ayrıca bakınız: is_array(), explode(), implode(), split(), preg_split() ve unset().

İçindekiler

  • array_change_key_case — Bir dizideki tüm anahtarların harf büyüklüğünü değiştirir
  • array_chunk — Bir diziyi belli uzunlukta bölümlere ayırır
  • array_column — Return the values from a single column in the input array
  • array_combine — Anahtarlar için bir dizi, değerler için ise başka bir dizi kullanarak bir ilişkisel dizi oluşturur
  • array_count_values — Bir dizideki tüm değerleri sayar
  • array_diff_assoc — Dizilerin farkını hesaplarken ek olarak indisleri de karşılaştırır
  • array_diff_key — Dizilerin farkını hesaplarken indisleri karşılaştırır
  • array_diff_uassoc — Dizilerin farkını hesaplarken ek olarak bir geriçağırım işlevi üzerinden indisleri de karşılaştırır
  • array_diff_ukey — Karşılaştırma için bir geriçağırım işlevi kullanarak dizilerin farkını hesaplar
  • array_diff — Dizilerin farkını hesaplar
  • array_fill_keys — Anahtarları belirtilen diziyi değerlerle doldurur
  • array_fill — Bir diziyi değerlerle doldurur
  • array_filter — Bir dizinin elemanlarını bir geriçağırım işleviyle süzgeçten geçirir
  • array_flip — Bir dizideki anahtarlarla değerleri yer değiştirir
  • array_intersect_assoc — Dizilerin kesişimini hesaplarken ek olarak indisleri de karşılaştırır
  • array_intersect_key — Karşılaştırma için anahtarları kullanarak dizilerin kesişimini hesaplar
  • array_intersect_uassoc — Dizilerin kesişimini hesaplarken ek olarak bir geriçağırım işlevi üzerinden indisleri de karşılaştırır
  • array_intersect_ukey — Anahtarları karşılaştırmak için bir geriçağırım işlevi kullanarak dizilerin kesişimini hesaplar
  • array_intersect — Dizilerin kesişimini hesaplar
  • array_key_exists — Belirtilen anahtar veya indis dizide var mı diye bakar
  • array_keys — Bir dizideki tüm anahtarları veya bir anahtar altkümesini döndürür
  • array_map — Belirtilen dizilerin elemanlarına geriçağırım işlevini uygular
  • array_merge_recursive — İki veya daha fazla sayıda diziyi ardarda ekleyerek yeni bir dizi oluşturur
  • array_merge — Belirtilen dizileri ardarda ekleyerek yeni bir dizi oluşturur
  • array_multisort — Çok sayıda diziyi veya çok boyutlu dizileri sıralar
  • array_pad — Dizi boyutunu belirtilen boyuta çıkarırken, yeni elemanlara belirtilen değeri yerleştirir
  • array_pop — Dizinin sonundaki elemanı diziden çıkartır
  • array_product — Bir dizideki değerlerin çarpımını bulur
  • array_push — Belli sayıda elemanı dizinin sonuna ekler
  • array_rand — Bir diziden belli sayıda rasgele eleman döndürür
  • array_reduce — Bir geriçağırım işlevini dizinin bütün elemanlarına tek tek uygulayıp sonucu döndürür
  • array_replace_recursive — İlk dizinin elemanlarını aktarılan dizilerden ardışık olarak günceller
  • array_replace — İlk dizinin elemanlarını aktarılan dizilerden günceller
  • array_reverse — Diziyi tersine sıralayıp döndürür
  • array_search — Bir dizide belirtilen değeri arar ve bulursa ilgili anahtarı döndürür
  • array_shift — Dizini başlangıcından bir eleman çeker
  • array_slice — Bir dizinin belli bir bölümünü döndürür
  • array_splice — Bir dizinin belli bir bölümünü silip yerine başka şeyler koyar
  • array_sum — Bir dizideki değerlerin toplamını hesaplar
  • array_udiff_assoc — Veri karşılaştırması için bir geriçağırım işlevi kullanarak diziler arasındaki farkı indislerine de bakarak bulur
  • array_udiff_uassoc — Veri ve indis karşılaştırması için bir geriçağırım işlevi kullanarak diziler arasındaki farkı indislerine de bakarak bulur
  • array_udiff — Veri karşılaştırması için bir geriçağırım işlevi kullanarak diziler arasındaki farkı bulur
  • array_uintersect_assoc — Veriyi bir geriçağırım işleviyle karşılaştırarak dizilerin kesişimini hesaplarken ek olarak indislere de bakar
  • array_uintersect_uassoc — Veriyi ve indisleri bir geriçağırım işleviyle karşılaştırarak dizilerin kesişimini hesaplarken ek olarak indislere de bakar
  • array_uintersect — Veriyi bir geriçağırım işleviyle karşılaştırarak dizilerin kesişimini hesaplar
  • array_unique — Diziden yinelenen değerleri siler
  • array_unshift — Bir dizinin başlangıcına bir veya daha fazla eleman ekler
  • array_values — Bir dizinin tüm değerlerini döndürür
  • array_walk_recursive — Bir dizinin ardışık olarak her üyesine kullanıcı tanımlı bir işlevi uygular
  • array_walk — Bir dizinin her üyesine kullanıcı tanımlı bir işlevi uygular
  • array — Bir dizi oluşturur
  • arsort — Bir dizinin değerlerini anahtarlarıyla ilişkilerini bozmadan tersine sıralar
  • asort — Bir dizinin değerlerini anahtarlarıyla ilişkilerini bozmadan sıralar
  • compact — Değişkenlerle değerlerinden oluşan bir dizi oluşturur
  • count — Bir dizideki eleman sayısını veya bir nesnedeki özellik sayısını döndürür
  • current — Bir diziden gösterici konumundaki elemanı döndürür
  • each — Bir diziden, gösterici konumundaki anahtar değer çiftini döndürdükten sonra göstericiyi bir ilerletir
  • end — Bir dizinin dahili göstericisini sonuncu elemana konumlandırır
  • extract — Bir dizideki değişkenleri simge tablosuna dahil eder
  • in_array — Bir dizide bir değerin varlığını araştırır
  • key_exists — Takma Adı: array_key_exists
  • key — Bir diziden gösterici konumundaki anahtarı döndürür
  • krsort — Bir diziyi anahtarlarına göre tersine sıralar
  • ksort — Bir diziyi anahtarlarına göre sıralar
  • list — Değişkenlere bir dizi gibi atama yapar
  • natcasesort — Bir diziyi harf büyüklüğüne duyarsız "doğal sıralama" algoritmasıyla sıralar
  • natsort — Bir diziyi "doğal sıralama" algoritmasıyla sıralar
  • next — Dahili dizi göstericisini bir ilerletir
  • pos — current işlevinin takma adıdır
  • prev — Dahili dizi göstericisini bir geriletir
  • range — Belli bir eleman aralığını içeren bir dizi oluşturur
  • reset — Bir dizinin dahili göstericisini ilk elemana konumlar
  • rsort — Bir diziyi tersine sıralar
  • shuffle — Bir diziyi karar
  • sizeof — count işlevinin takma adıdır
  • sort — Bir diziyi sıralar
  • uasort — Bir diziyi kullanıcı tanımlı bir işlev kullanarak indislerine göre sıralarken anahtar/değer ilişkisini korur
  • uksort — Bir diziyi kullanıcı tanımlı bir işlev kullanarak anahtarlarına göre sıralar
  • usort — Bir diziyi kullanıcı tanımlı bir işlev kullanarak değerlerine göre sıralar
add a note add a note

User Contributed Notes 11 notes

up
7
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!
up
2
seva dot lapsha at gmail dot com
5 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 (http://en.wikipedia.org/wiki/List_comprehension).

See the source code, examples and documentation at http://code.google.com/p/php-iterator-utils/
up
2
kolkabes at googlemail dot com
2 years ago
Short function for making a recursive array copy while cloning objects on the way.

<?php
function arrayCopy( array $array ) {
       
$result = array();
        foreach(
$array as $key => $val ) {
            if(
is_array( $val ) ) {
               
$result[$key] = arrayCopy( $val );
            } elseif (
is_object( $val ) ) {
               
$result[$key] = clone $val;
            } else {
               
$result[$key] = $val;
            }
        }
        return
$result;
}
?>
up
-1
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.

<?php
function array_rotate($array, $shift) {
    if(!
is_array($array) || !is_numeric($shift)) {
        if(!
is_array($array)) error_log(__FUNCTION__.' expects first argument to be array; '.gettype($array).' received.');
        if(!
is_numeric($shift)) error_log(__FUNCTION__.' expects second argument to be numeric; '.gettype($shift)." `$shift` received.");
        return
$array;
    }
   
$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:
<?php
$array
=array("foo"=>1,"bar"=>2,"baz"=>3,4,5);

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));
?>
up
-2
callmeanaguma at gmail dot com
1 year ago
If you need to flattern two-dismensional array with single values assoc subarrays, you could use this function:

<?php
function arrayFlatten($array) {
       
$flattern = array();
        foreach (
$array as $key => $value){
           
$new_key = array_keys($value);
           
$flattern[] = $value[$new_key[0]];
        }
        return
$flattern;
}
?>
up
-2
ob at babcom dot biz
8 years ago
Here is a function to find out the maximum depth of a multidimensional array.

<?php
// 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()) {
 
$DepthCount++;
  if (
is_array($Array))
    foreach (
$Array as $Key => $Value)
     
$DepthArray[]=ArrayDepth($Value,$DepthCount);
  else
    return
$DepthCount;
  foreach(
$DepthArray as $Value)
   
$Depth=$Value>$Depth?$Value:$Depth;
  return
$Depth;
}
?>
up
-3
mo dot longman at gmail dot com
7 years ago
to 2g4wx3:
i think better way for this is using JSON, if you have such module in your PHP. See json.org.

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.
up
-3
oliverSPAMMENOT at e-geek dot com dot au
4 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:

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

function egvaluetostring($value, $max_depth, $key = NULL, $depth = 0, $refChain = array()) {
  if(
$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;
          break;
        }
      }
     
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)) {
     
array_pop($refChain);
    }
  }
  else {
   
$text .= "$value";
  }

  return
$text;
}
?>
up
-4
rune at zedeler dot dk
7 years ago
Notice that keys are considered equal if they are "=="-equal. That is:

<?
$a = array();
$a[1] = 'this is the first value';
$a[true] = 'this value overrides the first value';
$a['1'] = 'so does this one';
?>
up
-4
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;
    else
        return false;
}
up
-8
Jck_true (leave out the &#39;_&#39; at gmail dot com)
6 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
<?php
$array
= flatten($array,'','{$','}','->');
echo
str_replace(array_keys($array),array_values($array),$template)
/**
* 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();
  foreach(
$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;
  }
  return
$return;
}
}
?>
Example:
$template = 'My string with replacement {$test->subkey}';
{$test->subkey} will get replaced with $array['test']['subkey']
To Top