PHP two-dimensional array sorting method (array_multisort usort)

高洛峰
Release: 2023-03-03 21:30:02
Original
2129 people have browsed it

For example, an array like the following:

$users = array( array('name' => 'tom', 'age' => 20) , array('name' => 'anny', 'age' => 18) , array('name' => 'jack', 'age' => 22) );
Copy after login

I hope it can be sorted by age from small to large. The author has sorted out two methods and shared them with you.

1. Use array_multisort

Using this method will be more troublesome. You need to extract the age and store it in a one-dimensional array, and then arrange it in ascending order by age. The specific code is as follows:

$ages = array(); foreach ($users as $user) { $ages[] = $user['age']; } array_multisort($ages, SORT_ASC, $users);
Copy after login

After execution, $users is a sorted array, which can be printed out to see. If you need to sort by age in ascending order first, and then by name in ascending order, the method is the same as above, that is, extract an additional name array. The final sorting method is called like this:

array_multisort($ages, SORT_ASC, $names, SORT_ASC, $users);
Copy after login

2. Use usort

The biggest advantage of using this method is that you can customize it Define some more complex sorting methods. For example, sort in descending order by name length:

usort($users, function($a, $b) { $al = strlen($a['name']); $bl = strlen($b['name']); if ($al == $bl) return 0; return ($al > $bl) ? -1 : 1; });
Copy after login

Anonymous functions are used here, and they can be extracted separately if necessary. Among them, $a and $b can be understood as elements under the $users array. You can directly index the name value, calculate the length, and then compare the lengths.

The author prefers the second method because it eliminates the step of extracting the sorted content into a one-dimensional array, and the sorting method is more flexible.

For more articles related to PHP two-dimensional array sorting method (array_multisort usort), please pay attention to the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!