сортировка массива по возрастанию php

Сортировка массивов в php: ksort, asort и прочие sort’ы

Поговорим о сортировке массивов.

Более подробную информацию и примеры вы всегда можете найти в документации по функциям сортировки.

Допустим у нас есть массив

Он неправильно отсортирован, как видите ключи (1,2,3) и значения (виноград, арбуз, банан) идут не по порядку. Давайте это исправим:

Сортировка массива по ключу

Сортировка массива по значению

Свои способы сортировки

Если предложенные способы сортировки вам не подходят, то можно создать свой способ сортировки ключей и значений массивов. Для этого есть 3 функции uasort, uksort и usort. С их помощью мы можем задать свою callback функцию, которая будет сравнивать элементы между собой и определять какой из них «больше» и какой «меньше».

Давайте рассмотрим как они работают напримере функции uasort, которая сравнивает значения с сохранением ключей.

Применить нашу новую функцию можно так:

Сохранение ключей означает, что каждый ключ как бы привязан к своему значению.

Если сортировка не дает ожидаемый результат, то изучите флаги сортировки. По умолчанию используется обычный тип сортировки SORT_REGULAR

Флаги типа сортировки:

Флаг сортировки передается в функцию сортировки, например так:

Сортировка многомерных массивов

Создадим функцию, которая нам поможет в сортировке массивов

Пример работы этой функции array_orderby() :

Если вам нужно что-то совсем уж специфическое при сортировки многомерных массивов

Можете создать и другие callback функции сортировки самостоятельно.

Массивы на «стероидах»

Часто работаете с массивами? Тогда вам понравится это расширение для работы с коллекциями.

Рассмотрим несколько примеров.

Простая сортировка чисел:

Сортировка по одной «колонке» ассоциативного массива:

Сортировка по нескольким аттрибутам одновременно:

Вы также можете использовать свои функции сортировки при работе с коллекциями:

Коллекции позволяют работать с массивами как в Laravel и функции этого замечательного инструмента далеко не ограничиваются сортировкой.

Изучите документацию и вы влюбитесь в коллекции.

Источник

Как сортировать массивы в PHP

Russian (Pусский) translation by Pembelight (you can also view the original English article)

Определенную информацию всегда легче получать из отсортированных данных, в обратном случае вам приходится пересматривать по очереди каждый элемент массива. Например, предположим, что вы храните оценки разных учеников одного класса в массиве или таблице. Если данные не отсортированы по оценкам, вам нужно пересмотреть оценку каждого учащегося, чтобы определить, кто получил самую высокую или или самую низкую. Если данные уже отсортированы от самой низкой к более высокой, то просто взглянув на оценку первого ученика, вы будете знать этот показатель.

Сортировка делает много простых и еффективных задач на основе доступа или получения определенного набора данных. В этом уроке мы узнаем, как использовать встроенные функции PHP для сортировки различных типов массивов.

Сортировка массива по значению

Вот несколько примеров, которые помогут вам быстро понять разницу между всеми типами сортировки.

В примере обычной сортировки числовые строки преобразуются в их числовые значения, и сортировка выполняется соответствующим образом. Строка «Apple» не является числовой, поэтому она остается нетронутой и сравнивается как строка.

Во втором примере наводится числовая сортировка, и мы хотим, чтобы данные сортировались по числовому значению, поэтому «Apple» преобразуется в числовое значение 0 и идет первым. Остальные значения отсортированы ожидаемым образом.

Сортировка ассоциативных массивов

Ассоциации ключевых значений важны, в случае если вы имеете дело с ассоциативными массивами. Рассмотрим следующий пример, где ассоциативный массив используется для хранения имен разных людей и их любимых фруктов. Если вы хотите отсортировать список в алфавитном порядке по названию фруктов, использование функции sort() из предыдущего раздела приведет к потере ассоциативных ключей.

Как видите, мы не только потеряли взаимосвязь между людьми и их любимыми фруктами, мы также потеряли имена этих людей. Каждому отсортированному значению был присвоен новый числовой индекс, основанный на его позиции в отсортированном массиве.

Сортировка элементов массива по значению с помощью пользовательских функций

С помощью разных значений вашим потребностям могут соответствовать четыре функции сортировки. Однако иногда ваши критерии сравнения элементов массива могут отличаться.

Допустим, у вас есть массив случайных слов, которые нужно отсортировать по алфавиту. Но перед этим вы ещё хотите их отсортировать по длине. Например, в традиционной алфавитной сортировке zoo будет следовать за apple. С другой стороны, если вы хотите показать сначала короткие слова, а потом длинные, то zoo появится перед apple. В том же наборе букв, ape будет перед zoo из-за алфавитного порядка.

В основном, слова сначала сортируются по длине, а затем слова с одинаковым количеством букв сортируются в алфавитном порядке в пределах своей группы. Этот тип сортировки не встроен в PHP, поэтому нам нужно написать собственную функцию.

Для таких случаев PHP предоставляет вам пару функций, которые можно использовать для передачи массива, подлежащий сортировке, вместе с именем вашей собственной функции сортировки.

Используйте функцию usort() для сортировки значений массива в обычных массивах. Точно так же можно использовать функцию uasort() для сортировки значений в ассоциативных массивах, сохраняя при этом ассоциаций ключевых значений.

Этот фрагмент кода показывает один из способов выполнения данной сортировки.

В функциях обратного вызова, предназначенных для пользовательской сортировки, мы должны вернуть целое число меньше 0, чтобы указать, что первое значение меньше второго. Если первое значение равно второму, возвращается 0. Если первое значение больше второго, возвращается целое число больше 0.

Как вы видите, в результате наша пользовательская функция сортировки переставляет слова в точности так, как мы хотели.

Сортировка массива по ключу

Вот основной пример сортировки:

В приведенном выше примере, чтобы отсортировать названия стран по длине их названия, а затем по алфавиту, мы использовали пользовательскую функцию сортировки из предыдущего раздела.

Сортировка многомерных массивов в PHP

В реальных проектах чаще всего имеют дело с многомерной информацией. Например, учебные заведения будут хранить оценки по разным предметам всех учащихся в одной таблице вместо создания новых таблиц для каждого предмета. Если вам понадобилось бы хранить похожую информацию в PHP, вы тоже предпочли использовать данный подход,а именно многомерный массив вместо отдельного массива для каждого предмета.

В этом уроке мы научимся сортировать многомерный массив, используя в качестве примера список самых высоких зданий в мире. Наш массив будет содержать информацию о здании: название, месторасположение (город, страна), количество этажей, общая высота в метрах, год постройки.

В конце мы просто перебираем основной массив и выводим информацию о каждом здании.

Послесловие

Источник

rsort

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

rsort — Сортирует массив в порядке убывания

Описание

Сортирует array по значению в порядке убывания.

Если оба сравниваемых значения эквивалентны, они сохраняют свой первоначальный порядок. До PHP 8.0.0 их относительный порядок в отсортированном массиве не был определён.

Список параметров

Необязательный второй параметр flags может использоваться для изменения поведения сортировки с использованием следующих значений:

Возвращаемые значения

Примеры

Пример #1 Пример использования rsort()

Результат выполнения данного примера:

Названия фруктов были отсортированы по алфавиту в обратном порядке.

Смотрите также

User Contributed Notes 6 notes

Like sort(), rsort() assigns new keys for the elements in array. It will remove any existing keys you may have assigned, rather than just reordering the keys. This means that it will destroy associative keys.

$animals = array(«dog»=>»large», «cat»=>»medium», «mouse»=>»small»);
print_r($animals);
//Array ( [dog] => large [cat] => medium [mouse] => small )

rsort($animals);
print_r($animals);
//Array ( [0] => small [1] => medium [2] => large )

Use KSORT() or KRSORT() to preserve associative keys.

A cleaner (I think) way to sort a list of files into reversed order based on their modification date.

Источник

arsort

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

arsort — Сортирует массив в порядке убывания и поддерживает ассоциацию индексов

Описание

Функция сортирует array в порядке убывания таким образом, что сохраняются отношения между ключами и значениями.

Она полезна, в основном, при сортировке ассоциативных массивов, когда важно сохранить отношение ключ => значение.

Если оба сравниваемых значения эквивалентны, они сохраняют свой первоначальный порядок. До PHP 8.0.0 их относительный порядок в отсортированном массиве не был определён.

Список параметров

Необязательный второй параметр flags может использоваться для изменения поведения сортировки с использованием следующих значений:

Возвращаемые значения

Примеры

Пример #1 Пример использования arsort()

Результат выполнения данного примера:

Названия фруктов были отсортированы в обратном порядке и ключи, ассоциированные с элементами, были сохранены.

Смотрите также

User Contributed Notes 6 notes

I have two servers; one running 5.6 and another that is running 7. Using this function on the two servers gets me different results when all of the values are the same.

?>

PHP 5.6 results:
Array ( [706] => 2 [703] => 2 [702] => 2 [696] => 2 [658] => 2 )
Array ( [658] => 2 [696] => 2 [702] => 2 [703] => 2 [706] => 2 )

PHP 7 results:
Array ( [706] => 2 [703] => 2 [702] => 2 [696] => 2 [658] => 2 )
Array ( [706] => 2 [703] => 2 [702] => 2 [696] => 2 [658] => 2 )

If you need to sort a multi-demension array, for example, an array such as

$TeamInfo[$TeamID][«WinRecord»]
$TeamInfo[$TeamID][«LossRecord»]
$TeamInfo[$TeamID][«TieRecord»]
$TeamInfo[$TeamID][«GoalDiff»]
$TeamInfo[$TeamID][«TeamPoints»]

and you have say, 100 teams here, and want to sort by «TeamPoints»:

first, create your multi-dimensional array. Now, create another, single dimension array populated with the scores from the first array, and with indexes of corresponding team_id. ie
$foo[25] = 14
$foo[47] = 42
or whatever.
Now, asort or arsort the second array.
Since the array is now sorted by score or wins/losses or whatever you put in it, the indices are all hoopajooped.
If you just walk through the array, grabbing the index of each entry, (look at the asort example. that for loop does just that) then the index you get will point right back to one of the values of the multi-dimensional array.
Not sure if that’s clear, but mail me if it isn’t.
-mo

Needed to get the index of the max/highest value in an assoc array.
max() only returned the value, no index, so I did this instead.

I was having trouble with the arsort() function on an older version of PHP which was returning an error along the lines of ‘wrong perameter count for function arsort’ when I tried to use a flag for numeric sorting (2/SORT_NUMERIC).
I figured, as I only wanted to sort integers, I could pad numbers from the left to a specific length with 0’s (using the lpad function provided by improv@magma.ca in the notes at http://www.php.net/manual/ref.strings.php).
A string sort then correctly sorts numerically (i.e. <30,2,10,21>becomes <030,021,010,002>not <30,21,2,10>) when echoing the number an (int)$string_name hides the leading 0’s.

A lot of people seem to trip up on this and ask me questions as to debugging. Bear in mind that this returns boolean, and does not return an array of affected items.

$array = array(«One»=>1, «Three» => 3,»Two» =>2);
print_r(asort($array));

If successful, will return 1, and error if there is a string used. Useful to note so then people stop asking me 😀

If you are dealing with a multidimensional array you want to sort, then this might be helpfull:

Источник

asort

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

asort — Сортирует массив в порядке возрастания и поддерживает ассоциацию индексов

Описание

Сортирует array в порядке возрастания, чтобы его ключи сохраняли свою корреляцию со значениями, с которыми они связаны.

Используется в основном при сортировке ассоциативных массивов, где важен фактический порядок элементов.

Если оба сравниваемых значения эквивалентны, они сохраняют свой первоначальный порядок. До PHP 8.0.0 их относительный порядок в отсортированном массиве не был определён.

Список параметров

Необязательный второй параметр flags может использоваться для изменения поведения сортировки с использованием следующих значений:

Возвращаемые значения

Примеры

Пример #1 Пример использования asort()

Результат выполнения данного примера:

Названия фруктов были отсортированы в алфавитном порядке и ключи, связанные с элементами, были сохранены.

Смотрите также

User Contributed Notes 31 notes

This function can be used to sort multidimensional arrays with almost no work whatsoever by using the individual values within the custom sort function.

This function passes the entire child element even if it is not a string. If it is an array, as would be the case in multidimensional arrays, it will pass the whole child array as one parameter.

Therefore, do something elegant like this:

// alphanumeric with case-sensitive data sorting by values
asort($exampleArray2, SORT_STRING | SORT_FLAG_CASE | SORT_NATURAL);

//output of defaut sorting
print_r($exampleArray1);
/*
* output of default sorting
Array
(
[5] => EXAMPLE10
[1] => Example10
[3] => Example2
[0] => example1
[6] => example10
[2] => example12
[4] => example3
)
*/

print_r($exampleArray2);
/*
* output of alphanumeric with case-sensitive data sorting by values
Array
(
[0] => example1
[3] => Example2
[4] => example3
[5] => EXAMPLE10
[1] => Example10
[6] => example10
[2] => example12
)
*/

For a recent project I needed to sort an associative array by value first, and then by key if a particular value appeared multiple times. I wrote this function to accomplish the task. Note that the parameters default to sort ascending on both keys and values, but allow granular control over each.

// Results
Array
(
[ pe ] => 1
[ ca ] => 1
[ ce ] => 1
[ cb ] => 2
[ pa ] => 2
)
Array
(
[ ca ] => 1
[ ce ] => 1
[ pe ] => 1
[ cb ] => 2
[ pa ] => 2
)
Array
(
[ cb ] => 2
[ pa ] => 2
[ ca ] => 1
[ ce ] => 1
[ pe ] => 1
)
Array
(
[ pa ] => 2
[ cb ] => 2
[ pe ] => 1
[ ce ] => 1
[ ca ] => 1
)

Small typo in the aksort function I just submitted. Here’s the entire thing again, with the correction noted:

This is a function to sort an indexed 2D array by a specified sub array key, either ascending or descending.

It is usefull for sorting query results from a database by a particular field after the query has been returned

This function can be quite greedy. It recreates the array as a hash to use ksort() then back again

Before: Array
(
[0] => Array ( [code] => LHR, [name] => Heathrow )
[1] => Array ( [code] => LGW, [name] => Gatwick )
)

After: Array
(
[0] => Array ( [code] => LGW, [name] => Gatwick )
[1] => Array ( [code] => LHR, [name] => Heathrow )
)

acecream’s function works fine, especially with the spectre extension.

nevertheless sometimes the index values have to be kept. To achieve this, just replace:

Case insensitive sort in one line:

This is a fixed version of the same function I posted below. Now it will handle duplicate entries in the sorted field. EG: If there were two records that had the name Heathrow it would still work.

Here’s my version of sorting multi-dimensional array by 2nd index.
Feel free to change the code to suit your needs.

Advanced sort array by second index function, which produces ascending (default) or descending output and uses optionally natural case insensitive sorting (which can be optionally case sensitive as well).
Only the first two arguments are required.

Similar to above but for an array of arrays instead of an array of objects.

Here’s one I whipped up to allow you to sort an array of a specific class by a member or function:

«This function sorts an array such that array indices maintain their correlation with the array elements they are associated with.»

Note this sentence in the description has a quite important implication especially when you’re working with an originally non-indexed (or say integer-indexed) array and JSON encoding/decoding.
I’m not reporting this as a bug, because the end result does fit into the description.

‘asort’ is fine for sorting arrays in English, but if accented characters exist in the array then it is better to use the ‘asort’ method of PHP’s Collator class:
https://www.php.net/manual/en/class.collator.php

$collator = new \Collator(‘fr_CA’);
$collator->asort($french_list);

There are options for using `setlocale()` to control `asort` behaviour, but it isn’t reliable across systems.
For instance, in my development environment I only have access to the following locals:

that works nicely, tho it breaks the result-array up if one or more of arrays indexes are deleted before sorting. this one should fix it up:

I use this for quasi-SQL orderby. Loosely based on smileaf. Any good for you nerds?

$girl_friends=array();
$girl_friends[«Anna»]=
array(«born»=>’1989-08-22′,»cupsize»=>’B-‘,»IQ»=>105, «daddy»=>’rich’);
$girl_friends[«Zoe»]
=array(«born»=>’1978-03-11′,»cupsize»=>’C#’,»IQ»=>130, «daddy»=>’poor’);
$girl_friends[«Lilly»]
=array(«born»=>’1985-06-16′,»cupsize»=>’DD’,»IQ»=>90, «daddy»=>’nasty’);

It is obviously necessary to log the keys used as so we don’t overwrite previous entries in the array ;o)

N.B. this also effects the timings, but still faster than the alternatives :

* int : 0.00159 (ms)
* str : 0.00092 (ms)

the idea is to take the key and sort(order) the specific column and then order the entire of the array as the selected column asort returned.

/**
*
* This sample is reading text data
* and perform a sort to a 2 dimensional array
* just like a normal sql do to «order by asc»
*
*/

// source file
$line_of_text [ 1 ] = ‘a1name|f2age|h3rank|jcolor’ ;
$line_of_text [ 2 ] = ‘b1name|d2age|i3rank|k4color’ ;
$line_of_text [ 0 ] = ‘c1name|e2age|g3rank|l4color’ ;

// start print
echo »

\n» ;
echo »

\n» ;
echo »

\n» ;
echo »

\n» ;
echo »

\n» ;
echo »

\n» ;
echo »

\n» ;
echo «

\n» ;

Well, actually, asort has *two* annoying features.

It works perfectly well sorting hashes (or associative arrays, as you might have it), but doggedly refuses to sort regular arrays maintaining index assocation. Kind’ve makes sense, but the docs don’t explicitly say you can’t do it.

Similar to above but for an array of arrays instead of an array of objects.

On sorting by value first, then by key (cf., 2008-01-31 notes by mike at clear-link dot com):

What occurred to me to solve this problem was to extract the keys and values into separate arrays, then use array_multisort to get the desired order:

Of course, array_multisort allows you to specify sort order (SORT_ASC, SORT_DESC) and sort type (SORT_REGULAR, SORT_STRING, SORT_NUMERIC) for each array you pass it.

Dear mike at clear-link dot com!

I needed a case insensitive version of your function. It is still not perfect as I have to do something with country specific characters (öüóőúéáűíÖÜÓŐÚÉÁŰÍ)

I have written this function so its sort an multidimensional array with a specific key.

Источник

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *

keynameagerankcolor