array_multisort
(PHP 4, PHP 5, PHP 7)
array_multisort — Sortiert mehrere oder multidimensionale Arrays
Beschreibung
&$array1
[, mixed $array1_sort_order
= SORT_ASC
[, mixed $array1_sort_flags
= SORT_REGULAR
[, mixed $...
]]] ) : boolarray_multisort() wird zum Sortieren von entweder mehreren Arrays auf einmal, oder eines multidimensionalen Arrays nach einer oder mehreren Dimensionen benutzt.
Assoziative (string) Schlüssel werden beibehalten, während numerische Schlüssel neu indexiert werden.
Parameter-Liste
-
array1
-
Ein zu sortierendes array.
-
array1_sort_order
-
Die Reihenfolge, die verwendet wird, um das vorangehende array Argument zu sortieren. Entweder
SORT_ASC
um aufsteigend, oderSORT_DESC
um absteigend zu sortieren.Dieses Argument kann mit
array1_sort_flags
vertauscht werden, oder ganz entfallen, in welchem FallSORT_ASC
angenommen wird. -
array1_sort_flags
-
Sortieroptionen für das vorangehende array Argument:
Sortier-Flags:
-
SORT_REGULAR
- vergleiche Elemente normal (ändere nicht die Typen) -
SORT_NUMERIC
- vergleiche Elemente numerisch -
SORT_STRING
- vergleiche Elemente als Zeichenketten -
SORT_LOCALE_STRING
- vergleiche Elemente als Zeichenketten, basierend auf dem aktuellen Gebietschema. Es verwendet das Gebietsschema, das unter Verwendung von setlocale() geändert werden kann -
SORT_NATURAL
- vergleiche Elemente als Zeichenketten unter Verwendung einer "natürlichen Ordnung" wie natsort() -
SORT_FLAG_CASE
- kann kombiniert werden (bitweises OR) mitSORT_STRING
oderSORT_NATURAL
um Zeichenketten case-insensitive zu sortieren
Dieses Argument kann mit
array1_sort_order
vertauscht werden, oder ganz entfallen, in welchem FallSORT_REGULAR
angenommen wird. -
-
...
-
Weitere Arrays, optional gefolgt von Sortierreihenfolge und -Flags. Nur zu äquivalenten Elementen in vorherigen Arrays korrespondierende Elemente werden verglichen. Anders ausgedrückt erfolgt die Sortierung lexikographisch.
Changelog
Version | Beschreibung |
---|---|
5.4.0 |
SORT_NATURAL und SORT_FLAG_CASE
wurden zu array1_sort_flags als mögliche Sortier-Flags hinzugefügt.
|
5.3.0 |
SORT_LOCALE_STRING wurde zu
array1_sort_flags als mögliches Sortier-Flag hinzugefügt.
|
Beispiele
Beispiel #1 Sortieren mehrerer Arrays
<?php
$ar1 = array(10, 100, 100, 0);
$ar2 = array(1, 3, 2, 4);
array_multisort($ar1, $ar2);
var_dump($ar1);
var_dump($ar2);
?>
In diesem Beispiel enthält das erste Array nach dem Sortieren 0, 10, 100, 100. Das zweite Array wird 4, 1, 2, 3 enthalten. Die Einträge des zweiten Arrays, welche den identischen Einträgen des ersten Arrays entsprechen (100 und 100), wurden ebenfalls sortiert.
array(4) { [0]=> int(0) [1]=> int(10) [2]=> int(100) [3]=> int(100) } array(4) { [0]=> int(4) [1]=> int(1) [2]=> int(2) [3]=> int(3) }
Beispiel #2 Sortieren eines mehrdimensionalen Arrays
<?php
$ar = array(
array("10", 11, 100, 100, "a"),
array( 1, 2, "2", 3, 1)
);
array_multisort($ar[0], SORT_ASC, SORT_STRING,
$ar[1], SORT_NUMERIC, SORT_DESC);
var_dump($ar);
?>
In diesem Beispiel wird sich das erste Array nach der Sortierung in "10", 100, 100, 11, "a" ändern (es wurde als Strings in aufsteigender Reihenfolge sortiert). Das zweite wird 1, 3, "2", 2, 1 enthalten (sortiert als Zahlen in absteigender Reihe).
array(2) { [0]=> array(5) { [0]=> string(2) "10" [1]=> int(100) [2]=> int(100) [3]=> int(11) [4]=> string(1) "a" } [1]=> array(5) { [0]=> int(1) [1]=> int(3) [2]=> string(1) "2" [3]=> int(2) [4]=> int(1) } }
Beispiel #3 Datenbankdaten sortieren
In diesem Beispiel repräsentiert jedes Element des Arrays data eine Zeile einer Tabelle. Dieser Typ von Datensätzen ist typisch für Datenbankinhalte.
Beispieldaten:
Band | Auflage -------+-------- 67 | 2 86 | 1 85 | 6 98 | 2 86 | 6 67 | 7
Die Daten als data genanntes Array. Dieses würde man üblicherweise erhalten, indem man zum Beispiel mit mysql_fetch_assoc() eine Schleife baut.
<?php
$data[] = array('Band' => 67, 'Auflage' => 2);
$data[] = array('Band' => 86, 'Auflage' => 1);
$data[] = array('Band' => 85, 'Auflage' => 6);
$data[] = array('Band' => 98, 'Auflage' => 2);
$data[] = array('Band' => 86, 'Auflage' => 6);
$data[] = array('Band' => 67, 'Auflage' => 7);
?>
In diesem Beispiel werden wir nach Band absteigend sortieren und nach Auflage aufsteigend.
Wir haben ein Array von Zeilen, aber array_multisort() benötigt ein Array von Spalten, daher benutzen wir den Code unten, um die Spalten zu bekommen und dann die Sortierung durchzuführen.
<?php
// Hole eine Liste von Spalten
foreach ($data as $key => $row) {
$band[$key] = $row['Band'];
$auflage[$key] = $row['Auflage'];
}
// von PHP 5.5.0 an kann array_column() statt des obigen Codes verwendet werden
$band = array_column($data, 'Band');
$auflage = array_column($data, 'Auflage');
// Die Daten mit 'Band' absteigend, die mit 'Auflage' aufsteigend sortieren.
// Geben Sie $data als letzten Parameter an, um nach dem gemeinsamen
// Schlüssel zu sortieren.
array_multisort($band, SORT_DESC, $auflage, SORT_ASC, $data);
?>
Der Datensatz ist jetzt sortiert und wird wie folgt aussehen:
Band | Auflage -----+-------- 98 | 2 86 | 1 86 | 6 85 | 6 67 | 2 67 | 7
Beispiel #4 Groß-/Kleinschreibung nicht-beachtende Sortierung
Sowohl SORT_STRING
als auch
SORT_REGULAR
beachten die Groß-/Kleinschreibung,
weshalb Strings, welche mit großem Buchstaben beginnen, vor Strings
einsortiert werden, die mit kleinem Buchstaben anfangen.
Um eine Suche durchzuführen, die die Groß-/Kleinschreibung nicht beachtet, muss man erzwingen, dass die Sortierreihenfolge von einer Kopie des Originalarrays in Kleinschreibung festgelegt wird.
<?php
$array = array('Alpha', 'atomar', 'Beta', 'bank');
$array_lowercase = array_map('strtolower', $array);
array_multisort($array_lowercase, SORT_ASC, SORT_STRING, $array);
print_r($array);
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
Array ( [0] => Alpha [1] => atomar [2] => bank [3] => Beta )
Siehe auch
- usort() - Sortiert ein Array nach Werten mittels einer benutzerdefinierten Vergleichsfunktion
- Den Vergleich von Arraysortierungsfunktionen
Deutsche Übersetzung
Sie haben gebeten, diese Seite auf Deutsch zu besuchen. Momentan ist nur die Oberfläche übersetzt, aber noch nicht der gesamte Inhalt.Wenn Sie mir bei Übersetzungen helfen wollen, ist Ihr Beitrag willkommen. Alles, was Sie tun müssen, ist, sich auf der Website zu registrieren und mir eine Nachricht zu schicken, in der Sie gebeten werden, Sie der Gruppe der Übersetzer hinzuzufügen, die Ihnen die Möglichkeit gibt, die gewünschten Seiten zu übersetzen. Ein Link am Ende jeder übersetzten Seite zeigt an, dass Sie der Übersetzer sind und einen Link zu Ihrem Profil haben.
Vielen Dank im Voraus.
Dokument erstellt 30/01/2003, zuletzt geändert 26/10/2018
Quelle des gedruckten Dokuments:https://www.gaudry.be/de/php-rf-array-multisort.html
Die Infobro ist eine persönliche Seite, deren Inhalt in meiner alleinigen Verantwortung liegt. Der Text ist unter der CreativeCommons-Lizenz (BY-NC-SA) verfügbar. Weitere Informationen auf die Nutzungsbedingungen und dem Autor.
Referenzen
Diese Verweise und Links verweisen auf Dokumente, die während des Schreibens dieser Seite konsultiert wurden, oder die zusätzliche Informationen liefern können, aber die Autoren dieser Quellen können nicht für den Inhalt dieser Seite verantwortlich gemacht werden.
Der Autor Diese Website ist allein dafür verantwortlich, wie die verschiedenen Konzepte und Freiheiten, die mit den Nachschlagewerken gemacht werden, hier dargestellt werden. Denken Sie daran, dass Sie mehrere Quellinformationen austauschen müssen, um das Risiko von Fehlern zu reduzieren.