Уроки PHP – як робити сортування даних в масиві

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

 

 

Введення в сортування масивів в PHP

Досить часто доводиться сортувати дані в масивах. Можливо, вам потрібно це робити в алфавітному або числовому порядку, в порядку зростання або зменшення. Для цього PHP надає декілька корисних функцій. У наступному розділі ми покажемо вам, як використовувати ці функції. Для початку візьмемо невеликий масив як приклад:

<?php
$masuvKolyoriv = array(
  "apple"  => "red",
  "grass"  => "green",
  "sky"    => "blue",
  "night"  => "black",
  "wall"   => "white"
);
?>

 

 

Тепер, якщо ви виведете масив, ви побачите елементи в тому ж порядку, в якому вони були визначені:

<?php
foreach ($masuvKolyoriv as $key => $value) {
  echo '<p>' . $key . ' - ' . $value . '</p>';
}
?>

 

 

Результат буде таким:

apple - red
grass - green
sky - blue
night - black
wall - white

 

 

Тепер перейдемо до процесу сортування цього масиву.

 

 

Основні функції сортування масиву в PHP

Для сортування масиву в PHP ви можете використовувати вбудовані функції sort і rsort. Різниця між ними полягає в тому, що rsort сортує масив у зворотному порядку (по зменшенню), а sort – в звичайному порядку (по зростанню).

Давайте подивимося, як це працює. Відсортуємо масив за допомогою функції sort, перш ніж відобразити його вміст. Код виглядає так:

<?php
sort($masuvKolyoriv);
foreach ($masuvKolyoriv as $key => $value) {
  echo '<p>' . $key . ' - ' . $value . '</p>';
}
?>

 

 

Результат буде таким:

0 - black
1 - blue
2 - green
3 - red
4 - white

 

 

Як ви могли помітити, ця функція призначає нові ключі для елементів в масиві. Функція сортування sort видаляє всі існуючі ключі, які ви могли призначити, замість того, щоб просто впорядкувати ключі. Вирішення цієї проблеми розглянемо пізніше.

Якщо вам потрібен зворотний порядок, єдине, що вам потрібно зробити, це використовувати замість цього функцію rsort, наприклад, так:

<?php
rsort($masuvKolyoriv);
foreach ($masuvKolyoriv as $key => $value) {
  echo '<p>' . $key . ' - ' . $value . '</p>';
}
?>

 

 

І результат буде наступний:

0 - white
1 - red
2 - green
3 - blue
4 - black

 

 

Тепер давайте дізнаємося, як вирішити проблему з втратою ключів, що важливо, якщо ви використовуєте асоціативні масиви.

 

 

Сортування асоціативних масивів в PHP

Як ми бачили раніше, функції sort і rsort не підійдуть, якщо нам потрібно зберегти ключі нашого масиву. На щастя, в PHP є вбудовані функції і для цієї проблеми. Функції називаються asort і arsort. За прикладом вищерозглянутих функцій, asort сортує по зростанню, а arsort – по спадаючій. Крім цього, дані функції підтримують збереження ключів масиву. Отже, давайте подивимося, як ці функції справляються з сортуванням даних в масиві. Повторимо наш тест з використанням нових функцій:

<?php
asort($masuvKolyoriv);
foreach ($masuvKolyoriv as $key => $value) {
  echo '<p>' . $key . ' - ' . $value . '</p>';
}
?>

 

 

Результат буде таким:

night - black
sky - blue
grass - green
apple - red
wall - white

 

 

Тепер результат виглядає набагато краще. Щоб отримати сортування в зворотному порядку, просто використовуйте функцію arsort замість asort.

Але що робити, якщо ви хочете відсортувати асоційовані масиви на основі ключів? Немає проблем, давайте подивимося як це зробити.

 

 

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

Ви вже певно здогадалися, що в PHP є функція сортування асоціативного масиву по ключах. Цими функціями є ksort і krsort. Як і раніше, krsort сортує масив у зворотному порядку. Використання таке ж, як і раніше, тому код буде наступним:

<?php
ksort($masuvKolyoriv);
foreach ($masuvKolyoriv as $key => $value) {
  echo '<p>' . $key . ' - ' . $value . '</p>';
}
?>

 

 

Результат буде таким:

apple - red
grass - green
night - black
sky - blue
wall - white

 

 

Використовувати функцію досить krsort просто.

 

Крім розглянутих функцій в PHP є й інші, більш складні функції сортування:

  • array_multisort – сортування декількох або багатовимірних масивів.
  • natcasesort – сортування масиву з використанням нечутливого до регістру алгоритму «природного порядку»
  • natsort – сортування масиву з використанням алгоритму «природного порядку».
  • uasort – сортує масив за допомогою користувальницької функції порівняння і підтримує зв’язок з індексами.
  • uksort – сортує масив по ключам, використовуючи призначену для користувача функцію порівняння
  • usort – сортує масив за значеннями, використовуючи призначену для користувача функцію порівняння

 

 

Бонусний навик: пошук в масиві за допомогою PHP

Уявіть собі, що у вас є великий масив, який заповнюється з файлу або коду. І ви не знаєте, чи існує дане значення в масиві чи ні. І якщо воно існує, то було б добре отримати ключ цього елемента.

Масив розглянемо той же (що на самому початку статті).

Тепер, якщо ви хочете дізнатися, чи існує значення blue, ви можете використовувати вбудовану в PHP функцію array_search(). Нижче приклад її використання:

<?php
echo 'Blue is ' . array_search("blue", $masuvKolyoriv);
?>

 

В результаті ви отримаєте таке значення:

Blue is sky

 

 

На сьогодні все, дякуємо, що читаєте нас!

 

This post was last modified on 10/12/2019 00:04

Останні пости

Вінстон Черчилль

Песиміст бачить труднощі у кожній можливості; оптиміст у будь-яких труднощах бачить можливості Сер Вінстон Леонард…

19/05/2024

Конфуцій

Коли вам здасться, що мета недосяжна, не змінюйте ціль — змінюйте свій план дій Конфуцій…

12/05/2024

Чарльз Дарвін

Виживає не найсильніший і не найрозумніший, а той, хто найкраще пристосовується до змін Чарльз Роберт…

11/05/2024

Що таке тег canvas в HTML5 і для чого він потрібен?

Елемент <canvas> з’явився лише в HTML5 і використовується для динамічного малювання графіки на веб-сторінці з…

10/05/2024

Ден Браун

Можливо все, — неможливе просто потребує більше часу Ден Браун  

09/05/2024

Що включає в себе чистка ноутбука?

Ноутбук — це не тільки зручний і функціональний ґаджет, а й доволі делікатний пристрій, що…

08/05/2024