Pythons Analogon zur PHP-Natsort-Funktion: Sortierung in natürlicher Reihenfolge
Natürliche Sortieralgorithmen sortieren Listen von Zeichenfolgen in einer für Menschen lesbaren Reihenfolge und gruppieren Zahlen und andere Charaktere zusammen. Im Gegensatz zur Standardsortiermethode, die „12“ als kleiner als „3“ behandelt, würden natürliche Sortierungen [„1“, „10“, „12“, „3“] ergeben.
In Python eins kann eine natürliche Sortierfunktion mithilfe einer benutzerdefinierten Schlüsselfunktion implementieren. Das folgende Code-Snippet stellt eine Implementierung ähnlich dem Natsort von PHP bereit:
<code class="python">import re def natural_key(string_): """See https://blog.codinghorror.com/sorting-for-humans-natural-sort-order/""" return [int(s) if s.isdigit() else s for s in re.split(r'(\d+)', string_)]</code>
Beispiel:
<code class="python">L = ['image1.jpg', 'image15.jpg', 'image12.jpg', 'image3.jpg'] sorted(L) # Output: ['image1.jpg', 'image12.jpg', 'image15.jpg', 'image3.jpg'] sorted(L, key=natural_key) # Output: ['image1.jpg', 'image3.jpg', 'image12.jpg', 'image15.jpg']</code>
Verwenden Sie für Unicode-Strings isdecimal() anstelle von isdigit(). Für Bytestrings unter Python 2 sollte bytestring.decode().isdigit() verwendet werden.
Das obige ist der detaillierte Inhalt vonWie implementiert man Pythons Äquivalent zur Natsort-Funktion von PHP?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!