Heim  >  Artikel  >  Backend-Entwicklung  >  Zusammenfassung der Verwendung verschiedener Sortierfunktionen in PHP

Zusammenfassung der Verwendung verschiedener Sortierfunktionen in PHP

伊谢尔伦
伊谢尔伦Original
2017-06-26 13:17:061487Durchsuche

Wenn Sie PHP schon länger verwenden, sollten Sie bereits mit seinen Arrays vertraut sein – diese Datenstruktur ermöglicht es Ihnen, mehrere Werte in einer einzigen Variablen zu speichern und sie als Operate für eine Sammlung zu verwenden.

Entwickler finden es oft nützlich, Werte oder Array-Elemente mithilfe dieser Datenstruktur in PHP zu sortieren. PHP bietet einige Sortierfunktionen für eine Vielzahl von Arrays. Mit diesen Funktionen können Sie Elemente innerhalb des Arrays anordnen und sie auf viele verschiedene Arten neu anordnen. In diesem Artikel besprechen wir einige der wichtigsten Funktionen dieser Sortierung.

Einfache Sortierung

Schauen wir uns zunächst den einfachsten Fall an: das einfache Sortieren eines Array-Elements von niedrig nach hoch. Diese Funktion kann entweder numerisch verwendet werden Die Anordnung kann auch alphabetisch erfolgen. Die Funktion sort() von PHP implementiert diese Funktion, wie in Listing A gezeigt:

Listing A

<?php
$data = array(5,8,1,7,2);
sort($data);
print_r($data);
?>

Das Ausgabeergebnis ist wie folgt Anzeige:

Array ([0] => 1
[1] => 2
[2] => 5
[3] => 7
[4] => 8
)

Sie können zum Sortieren auch die Funktion rsort() verwenden, deren Ergebnis das Gegenteil des einfachen Sortierergebnisses von sort() ist, das zuvor verwendet wurde. Die Funktion Rsort() sortiert die Array-Elemente von hoch nach niedrig, entweder numerisch oder alphabetisch. Listing B zeigt uns ein Beispiel dafür:

Listing B

<?php 
$data = array(5,8,1,7,2);
rsort($data);
print_r($data);
?>

Die Ausgabe lautet wie folgt:

Array ([0] => 8
[1] => 7
[2] => 5
[3] => 2
[4] => 1
)

Nach Schlüsselwörtern sortieren

Wenn wir Arrays verwenden, ordnen wir das Array häufig nach Schlüsselwörtern neu, von hoch nach niedrig. Die Funktion Ksort() ist eine Funktion, die nach Schlüsselwörtern sortiert und gleichzeitig die Relevanz von Schlüsselwörtern während des Sortiervorgangs beibehält. Listing C ist ein Beispiel:

Listing C

<?php 
$data = array("US" => "United States", "IN" => "India", "DE" => "Germany", "ES" => "Spain");
ksort($data); 
print_r($data);
?>

Die Ausgabe lautet wie folgt:

Array ([DE] => Germany
[ES] => Spain
[IN] => India
[US] => United States
)

Die Funktion Krsort() sortiert das Array nach Schlüsselwörtern:

Listing D

<?php 
$data = array("US" => "United States", "IN" => "India", "DE" => "Germany", "ES" => "Spain");
krsort($data); 
print_r($data);
?>

Die Ausgabe lautet wie folgt:

Array ([US] => United States
[IN] => India
[ES] => Spain
[DE] => Germany
)

Nach Wert sortieren

Wenn Sie die Wertesortierung anstelle der Schlüsselwortsortierung verwenden möchten, kann PHP auch Ihre Anforderungen erfüllen. Sie müssen lediglich die Funktion asort() anstelle der zuvor erwähnten Funktion ksort() verwenden. Wie in Listing E gezeigt:

Listing E

<?php 
$data = array("US" => "United States", "IN" => "India", "DE" => "Germany", "ES" => "Spain");
asort($data); 
print_r($data);
?>

Das Folgende ist die Ausgabe. Beachten Sie den Unterschied zwischen diesem Ergebnis und dem Ergebnis, das mit der Funktion ksort() oben erhalten wurde – in beiden Fällen erfolgt die Sortierung alphabetisch, sie werden jedoch nach verschiedenen Feldern des Arrays sortiert.

同时,请注意关键字-值之间的联系会始终保持;它只是关键字-值对排序后的一种方式,排序并不会改变它们的对应关系。

Array ([DE] => Germany
[IN] => India
[ES] => Spain
[US] => United States
)

现在,你肯定能猜到这种排序也可以进行倒排,它使用arsort()函数完成这个功能。Listing F就是一个例子:

Listing F

<?php 
$data = array("US" => "United States", "IN" => "India", "DE" => "Germany", "ES" => "Spain");
arsort($data); 
print_r($data);
?>

下面是它的输出结果,根据值按字母表顺序进行倒排。将下面的结果与用krsort()函数进行倒排后生成的结果进行比较,就能很容易明白两者的不同了。

Array ([US] => United States
[ES] => Spain
[IN] => India
[DE] => Germany
)

自然语言排序

PHP有一个非常独特的排序方式,这种方式使用认知而不是使用计算规则。这种特性称为自然语言排序,当创建模糊逻辑应用软件的时候这种排序方式非常有用。下面大家可以来看看它的一个简单例子,如Listing G所示:

Listing G

<?php 
$data = array("book-1", "book-10", "book-100", "book-5"); 
sort($data);
print_r($data);
natsort($data); 
print_r($data);
?>

它的输出结果如下:

Array ([0] => book-1
[1] => book-10
[2] => book-100
[3] => book-5
)
Array
(
[0] => book-1
[3] => book-5
[1] => book-10
[2] => book-100
)

它们的不同已经很清楚了:第二个排序结果更直观,更“人性化”,然而第一个则更符合算法规则,更具“计算机”特点。

自然语言能进行倒排吗?答案是肯定的!只要对natsort()的结果使用array_reverse()函数就可以了,Listing H就是一个简单例子:

Listing H

<?php 
$data = array("book-1", "book-10", "book-100", "book-5");
natsort($data); 
print_r(array_reverse($data));
?>

下面是它的输出结果:

Array ([0] => book-100
[1] => book-10
[2] => book-5
[3] => book-1
)

根据用户自定义的规则排序

PHP也能让你定义自己的排序算法,你可以通过创建你自己的比较函数,并把它传递给usort()函数。如果第一个参数比第二个参数“小”的话,比较函数必须返回一个比0小的数,如果第一参数比第二个参数“大”的话,比较函数应该返回一个比0大的数。

Listing I就是这样的一个例子,在这个例子中根据它们的长度对数组元素进行排序,最短的项放在最前面:

Listing I

<?php 
$data = array("joe@host.com", "john.doe@gh.co.uk", "asmithsonian@us.info", "jay@zoo.tw");
usort($data, &#39;sortByLen&#39;);
print_r($data); 
function sortByLen($a, $b) {
if (strlen($a) == strlen($b)) {
return 0;
} else {
return (strlen($a) > strlen($b)) ? 1 : -1;
}
}
?>

这样,就创建了我们自己的比较函数,这个函数使用strlen()函数比较每一个字符串的个数,然后分别返回1,0或-1.这个返回值是决定元素排列的基础。下面是它的输出结果:

Array ([0] => jay@zoo.tw
[1] => joe@host.com
[2] => john.doe@gh.co.uk
[3] => asmithsonian@us.info
)

自然语言排序

PHP有一个非常独特的排序方式,这种方式使用认知而不是使用计算规则。这种特性称为自然语言排序,当创建模糊逻辑应用软件的时候这种排序方式非常有用。下面大家可以来看看它的一个简单例子,如Listing G所示:

Listing G

<?php 
$data = array("book-1", "book-10", "book-100", "book-5"); 
sort($data);
print_r($data);
natsort($data); 
print_r($data);
?>

它的输出结果如下:

Array ([0] => book-1
[1] => book-10
[2] => book-100
[3] => book-5
)
Array
(
[0] => book-1
[3] => book-5
[1] => book-10
[2] => book-100
)

它们的不同已经很清楚了:第二个排序结果更直观,更“人性化”,然而第一个则更符合算法规则,更具“计算机”特点。

自然语言能进行倒排吗?答案是肯定的!只要对natsort()的结果使用array_reverse()函数就可以了,Listing H就是一个简单例子:

Listing H

<?php 
$data = array("book-1", "book-10", "book-100", "book-5");
natsort($data); 
print_r(array_reverse($data));
?>

下面是它的输出结果:

Array ([0] => book-100
[1] => book-10
[2] => book-5
[3] => book-1
)

根据用户自定义的规则排序

PHP也能让你定义自己的排序算法,你可以通过创建你自己的比较函数,并把它传递给usort()函数。如果第一个参数比第二个参数“小”的话,比较函数必须返回一个比0小的数,如果第一参数比第二个参数“大”的话,比较函数应该返回一个比0大的数。

Listing I就是这样的一个例子,在这个例子中根据它们的长度对数组元素进行排序,最短的项放在最前面:

Listing I

<?php 
$data = array("joe@host.com", "john.doe@gh.co.uk", "asmithsonian@us.info", "jay@zoo.tw");
usort($data, &#39;sortByLen&#39;);
print_r($data); 
function sortByLen($a, $b) {
if (strlen($a) == strlen($b)) {
return 0;
} else {
return (strlen($a) > strlen($b)) ? 1 : -1;
}
}
?>

这样,就创建了我们自己的比较函数,这个函数使用strlen()函数比较每一个字符串的个数,然后分别返回1,0或-1.这个返回值是决定元素排列的基础。下面是它的输出结果:

Array ([0] => jay@zoo.tw
[1] => joe@host.com
[2] => john.doe@gh.co.uk
[3] => asmithsonian@us.info
)

多维排序

最后,PHP也允许在多维数组上执行一些比较复杂的排序——例如,首先对一个嵌套数组使用一个普通的关键字进行排序,然后再根据另一个关键字进行排序。这与使用SQL的ORDER BY语句对多个字段进行排序非常相似。为了能更好的明白它是如何工作的,请仔细看Listing J所举的例子:

Listing J

<?php 
$data = array(array("id" => 1, "name" => "Boney M", "rating" => 3),
array("id" => 2, "name" => "Take That", "rating" => 1),
array("id" => 3, "name" => "The Killers", "rating" => 4),
array("id" => 4, "name" => "Lusain", "rating" => 3),
); 
foreach ($data as $key => $value) {
$name[$key] = $value[&#39;name&#39;];
$rating[$key] = $value[&#39;rating&#39;];
}
array_multisort($rating, $name, $data); 
print_r($data);
?>

这里,我们在$data数组中模拟了一个行和列数组。然后,我使用array_multisort()函数对数据集合进行重排,首先是根据rating进行排序,然后,如果rating相等的话,再根据name排序。它的输出结果如下:

Array ([0] => Array
(
[id] => 2
[name] => Take That
[rating] => 1
) 
[1] => Array
(
[id] => 1
[name] => Boney M
[rating] => 3
)
[2] => Array
(
[id] => 4
[name] => Lusain
[rating] => 3
)
[3] => Array
(
[id] => 3
[name] => The Killers
[rating] => 4
)
)

array_multisort()函数是PHP中最有用的函数之一,它有非常广泛的应用范围。另外,就如你在例子中所看到的,它能对多个不相关的数组进行排序,也可以使用其中的一个元素作为下次排序的基础,还可以对数据库结果集进行排序。

这些例子应该让你对PHP中各种数组排序函数的使用有了初步的了解,也向你展示了一些隐藏在PHP数组处理工具包的内部功能。


Das obige ist der detaillierte Inhalt vonZusammenfassung der Verwendung verschiedener Sortierfunktionen in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn