1
0
mirror of https://github.com/php/doc-de.git synced 2026-03-26 00:02:18 +01:00
Files
archived-doc-de/reference/array/functions/array-multisort.xml
2008-11-05 01:40:37 +00:00

312 lines
8.7 KiB
XML

<?xml version="1.0" encoding="iso-8859-1"?>
<!-- $Revision: 1.13 $ -->
<!-- EN-Revision: 1.19 Maintainer: nobody Status: ready -->
<!-- CREDITS: tom -->
<refentry xml:id="function.array-multisort" xmlns="http://docbook.org/ns/docbook">
<refnamediv>
<refname>array_multisort</refname>
<refpurpose>Sortiert mehrere oder multidimensionale Arrays</refpurpose>
</refnamediv>
<refsect1 role="description">
&reftitle.description;
<methodsynopsis>
<type>bool</type><methodname>array_multisort</methodname>
<methodparam><type>array</type><parameter>ar1</parameter></methodparam>
<methodparam choice="opt"><type>mixed</type><parameter>arg</parameter></methodparam>
<methodparam choice="opt"><type>mixed</type><parameter>...</parameter></methodparam>
<methodparam choice="opt"><type>array</type><parameter>...</parameter></methodparam>
<!-- Parameters don't need to be passed by reference -->
</methodsynopsis>
<para>
&return.success;
</para>
<para><function>array_multisort</function> wird zum Sortieren von
entweder mehreren Arrays auf einmal, oder eines
multidimensionalen Arrays nach einer oder mehreren Dimensionen
benutzt. Bei der Sortierung werden die
Schlüsselassoziationen beibehalten.
</para>
<para>
Assoziative (<type>string</type>) Schlüssel werden beibehalten, aber
numerische Schlüssel werden neu nummeriert.
</para>
<para>
Die angegebenen Arrays werden als Spalten einer Tabelle
behandelt, welche nach Reihen sortiert werden - ähnlich der SQL
Klausel ORDER BY. Das erste Array ist auch das erste in der
Sortierreihenfolge. Die in diesem Array gleichen Zeilen (Werte)
werden anhand des nächsten angegebenen Arrays sortiert, usw.
</para>
<para>
Die Struktur der Argumente ist etwas ungewöhnlich, aber
flexibel. Das erste Argument muss ein Array sein. Die
nachfolgenden Argumente können entweder ein Array oder eines der
folgenden Sortierflags sein.
</para>
<para>
Flags für Sortierreihenfolge:
<itemizedlist>
<listitem>
<simpara><constant>SORT_ASC</constant> - sortiere in aufsteigender Reihenfolge</simpara>
</listitem>
<listitem>
<simpara><constant>SORT_DESC</constant> - sortiere in absteigender Reihenfolge</simpara>
</listitem>
</itemizedlist>
</para>
<para>
Flags für Sortiertypen:
<itemizedlist>
<listitem>
<simpara><constant>SORT_REGULAR</constant> - vergleiche Felder normal</simpara>
</listitem>
<listitem>
<simpara><constant>SORT_NUMERIC</constant> - vergleiche Felder numerisch</simpara>
</listitem>
<listitem>
<simpara><constant>SORT_STRING</constant> - vergleiche Felder als Strings</simpara>
</listitem>
</itemizedlist>
</para>
<para>
Es kann nur ein Sortierflag des selben Typs nach jedem Array
spezifiziert werden. Sortierflags nach einem Array Argument
gelten nur für dieses Array, und werden vor jedem neuen Array
Argument zu den Defaultflags <constant>SORT_ASC</constant> und
<constant>SORT_REGULAR</constant> zurückgesetzt.
</para>
<para>
&return.success;
</para>
<para>
<example>
<title>Sortieren mehrerer Arrays</title>
<programlisting role="php">
<![CDATA[
<?php
$ar1 = array("10", 100, 100, "a");
$ar2 = array(1, 3, "2", 1);
array_multisort($ar1, $ar2);
?>
]]>
</programlisting>
<para>
In diesem Beispiel enthält das erste Array nach dem Sortieren 10,
"a", 100, 100. Das zweite Array wird 1, 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.
</para>
<screen>
<![CDATA[
array(4) {
[0]=> string(2) "10"
[1]=> string(1) "a"
[2]=> int(100)
[3]=> int(100)
}
array(4) {
[0]=> int(1)
[1]=> int(1)
[2]=> string(1) "2"
[3]=> int(3)
}
]]>
</screen>
</example>
</para>
<para>
<example>
<title>Sortieren eines mehrdimensionalen Arrays</title>
<programlisting role="php">
<![CDATA[
<?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);
?>
]]>
</programlisting>
<para>
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).
</para>
<screen>
<![CDATA[
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)
}
}
]]>
</screen>
</example>
</para>
<para>
<example>
<title>Datenbankdaten sortieren</title>
<para>
In diesem Beispiel repräsentiert jedes Element des Arrays
<varname>data</varname> eine Zeile einer Tabelle. Dieser Typ
von Datensätzen ist typisch für Datenbankinhalte.
</para>
<para>
Beispieldaten:
</para>
<screen>
<![CDATA[
Band | Auflage
-------+--------
67 | 2
86 | 1
85 | 6
98 | 2
86 | 6
67 | 7
]]>
</screen>
<para>
Die Daten als <varname>data</varname> genanntes Array. Dieses würde
üblicherweise erhalten, indem man zum Beispiel mit
<function>mysql_fetch_assoc</function> eine Schleife baut.
</para>
<programlisting role="php">
<![CDATA[
<?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);
?>
]]>
</programlisting>
<para>
In diesem Beispiel werden wir nach <varname>Band</varname> absteigend
sortieren und nach <varname>Auflage</varname> aufsteigend.
</para>
<para>
Wir haben ein Array von Zeilen, aber
<function>array_multisort</function> benötigt ein Array von Spalten,
daher benutzen wir den Code unten, um die Spalten zu bekommen und
dann die Sortierung durchzuführen.
</para>
<programlisting role="php">
<![CDATA[
<?php
// Hole eine Liste von Spalten
foreach ($data as $key => $row) {
$band[$key] = $row['Band'];
$auflage[$key] = $row['Auflage'];
}
// Die Daten mit band absteigend, 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);
?>
]]>
</programlisting>
<para>
Der Datensatz ist jetzt sortiert und wird wie folgt aussehen:
</para>
<screen>
<![CDATA[
Band | Auflage
-------+--------
98 | 2
86 | 1
86 | 6
85 | 6
67 | 2
67 | 7
]]>
</screen>
</example>
</para>
<para>
<example>
<title>Groß-/Kleinschreibung nicht beachtende Sortierung</title>
<para>
Sowohl <constant>SORT_STRING</constant> als auch
<constant>SORT_REGULAR</constant> beachten die Groß-/Kleinschreibung,
weshalb Strings, welche mit großem Buchstaben beginnen, vor Strings
einsortiert werden, die mit kleinem Buchstaben anfangen.
</para>
<para>
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.
</para>
<programlisting role="php">
<![CDATA[
<?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);
?>
]]>
</programlisting>
&example.outputs;
<screen>
<![CDATA[
Array
(
[0] => Alpha
[1] => atomar
[2] => bank
[3] => Beta
)
]]>
</screen>
</example>
</para>
</refsect1>
</refentry>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"../../../../manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->