Maison >développement back-end >Tutoriel Python >Comment implémenter l'équivalent Python de la fonction natsort de PHP ?

Comment implémenter l'équivalent Python de la fonction natsort de PHP ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-11-05 21:36:02510parcourir

How to Implement Python's Equivalent of PHP's natsort Function?

Analogue de Python à la fonction natsort de PHP : tri par ordre naturel

Les algorithmes de tri naturel trient les listes de chaînes dans un ordre lisible par l'homme, regroupant les nombres et d'autres personnages ensemble. Contrairement à la méthode de tri par défaut, qui traite "12" comme inférieur à "3", les tris naturels produiraient ["1", "10", "12", "3"].

En Python, un peut implémenter une fonction de tri naturel à l'aide d'une fonction clé personnalisée. L'extrait de code suivant fournit une implémentation similaire au natsort de PHP :

<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>

Exemple :

<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>

Pour les chaînes Unicode, utilisez isdecimal() au lieu de isdigit(). Pour les chaînes d'octets sur Python 2, bytestring.decode().isdigit() doit être utilisé.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn