downloads | documentation | faq | getting help | mailing lists | licenses | wiki | reporting bugs | php.net sites | conferences | my php.net

search for in the

Dizi İşlevleri> <Öntanımlı Sabitler
[edit] Last updated: Fri, 17 May 2013

view this page in

Dizilerde Sıralama

PHP, dizileri sıralamak için kullanılabilen çeşitli işlevlere sahiptir ve bu belgede bunların kullanımları ele alınmıştır.

Bu işlevler arasındaki başlıca farklar şunlardır:

  • Bazı sıralama işlemleri dizilerin anahtarlarına göre yapılırken bazılarında değerlere göre yapılır: $dizi['anahtar'] = 'değer';
  • Anahtarların sayısal olarak ele alındığı durumda sıralama sonrası anahtarlarla değerleri arasındaki ilişki bozulmuş olabilir de olmayabilir de.
  • Sıralama çeşitleri: abecesel, küçükten büyüğe (artan), büyükten küçüğe (azalan), sayısal, doğal, rasgele, kullanıcı tanımlı
  • Dikkat: Sıralama işlevlerinin hepsi doğrudan dizi üzerinde çalışmazlar; bazıları sonucu başka bir dizide döndürebilir.
  • Bu sıralama işlevlerinin işleme soktuğu üyelerden ikisi birbirine eşitse sıralama istenen sonucu vermeyebilir.

Sıralama işlevleri ve özellikleri
İşlev ismi Sıralama yeri Anahtar değer ilişkisi Sıralama kuralı İlgili işlevler
array_multisort() değer ilişkiselse korunur, sayısalsa korunmaz ilk dizi veya sıralama seçenekleri array_walk()
asort() değer korunur küçükten büyüğe arsort()
arsort() değer korunur büyükten küçüğe asort()
krsort() key korunur büyükten küçüğe ksort()
ksort() key korunur küçükten büyüğe asort()
natcasesort() değer korunur doğal, harf büyüklüğüne duyarsız natsort()
natsort() değer korunur doğal natcasesort()
rsort() değer korunmaz büyükten küçüğe sort()
shuffle() değer korunmaz rasgele array_rand()
sort() değer korunmaz küçükten büyüğe rsort()
uasort() değer korunur kullanıcı tanımlı uksort()
uksort() key korunur kullanıcı tanımlı uasort()
usort() değer korunmaz kullanıcı tanımlı uasort()



Dizi İşlevleri> <Öntanımlı Sabitler
[edit] Last updated: Fri, 17 May 2013
 
add a note add a note User Contributed Notes Dizilerde Sıralama - [4 notes]
up
1
&#34;Matthew Rice&#34;
4 days ago
While this may seem obvious, user-defined array sorting functions ( uksort(), uasort(), usort() ) will *not* be called if the array does not have *at least two values in it*.

The following code:                       

<?php

function usortTest($a, $b) {
   
var_dump($a);
   
var_dump($b);
    return -
1;
}

$test = array('val1');
usort($test, "usortTest");

$test2 = array('val2', 'val3');
usort($test2, "usortTest");

?>

Will output:

string(4) "val3"
string(4) "val2"

The first array doesn't get sent to the function.

Please, under no circumstance, place any logic that modifies values, or applies non-sorting business logic in these functions as they will not always be executed.
up
9
oculiz at gmail dot com
2 years ago
Another way to do a case case-insensitive sort by key would simply be:

<?php
uksort
($array, 'strcasecmp');
?>

Since strcasecmp is already predefined in php it saves you the trouble to actually write the comparison function yourself.
up
-5
Dirk
3 years ago
If you need to perform any of these sort functions on an array containing two or more equivalent values, you can get the equivalents to fall next to each other within the overall ordering (similar to how MySQL's ORDER BY works...) instead of breaking the sort() function, by using ksort() as a second parameter to arbitrarily distinguish any equivalent values by their unique keys:

<?php

sort
($array, ksort($array));

?>

Seems like this effect should be built in.  At least the workaround is so short...
up
-2
K.i.n.g.d.r.e.a.d
3 years ago
If you search a feature which sorts an array incasesensitive by key, try this:

<?php
function isort($a,$b) {
    return
strtolower($a)>strtolower($b);
}
uksort($array, "isort");
?>

 
show source | credits | stats | sitemap | contact | advertising | mirror sites