Existe-t-il un moyen simple de trier les lettres d'une chaîne par ordre alphabétique en Python?
Donc pour:
a = 'ZENOVW'
Je voudrais revenir:
'ENOVWZ'
Existe-t-il un moyen simple de trier les lettres d'une chaîne par ordre alphabétique en Python?
Donc pour:
a = 'ZENOVW'
Je voudrais revenir:
'ENOVWZ'
Réponses:
Tu peux faire:
>>> a = 'ZENOVW'
>>> ''.join(sorted(a))
'ENOVWZ'
''.join(sorted(a, reverse=True, key=str.lower))peut être utilisé pour effectuer un tri inversé insensible à la casse. Cela pourrait être pratique.
La solution Sorted () peut vous donner des résultats inattendus avec d'autres chaînes.
Liste des autres solutions:
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s.lower())))
' belou'
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s)))
' Bbelou'
>>> s = "Bubble Bobble"
>>> ''.join(sorted(s))
' BBbbbbeellou'
Si vous voulez vous débarrasser de l'espace dans le résultat, ajoutez la fonction strip () dans l'un de ces cas mentionnés:
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s.lower()))).strip()
'belou'
La fonction Python sortedrenvoie un résultat basé sur ASCII pour la chaîne.
INCORRECT : dans l'exemple ci-dessous, eet dest en retard Het en Wraison de sa valeur ASCII.
>>>a = "Hello World!"
>>>"".join(sorted(a))
' !!HWdellloor'
CORRECT : pour écrire la chaîne triée sans changer la casse de la lettre. Utilisez le code:
>>> a = "Hello World!"
>>> "".join(sorted(a,key=lambda x:x.lower()))
' !deHllloorW'
Si vous souhaitez supprimer tous les signes de ponctuation et les chiffres. Utilisez le code:
>>> a = "Hello World!"
>>> "".join(filter(lambda x:x.isalpha(), sorted(a,key=lambda x:x.lower())))
'deHllloorW'
le code peut être utilisé pour trier la chaîne par ordre alphabétique sans utiliser aucune fonction intégrée de python
k = input ("Entrez à nouveau une chaîne")
li = []
x = len(k)
for i in range (0,x):
li.append(k[i])
print("List is : ",li)
for i in range(0,x):
for j in range(0,x):
if li[i]<li[j]:
temp = li[i]
li[i]=li[j]
li[j]=temp
j=""
for i in range(0,x):
j = j+li[i]
print("After sorting String is : ",j)
J'ai vraiment aimé la réponse avec la fonction reduction (). Voici une autre façon de trier la chaîne en utilisant accumulate ().
from itertools import accumulate
s = 'mississippi'
print(tuple(accumulate(sorted(s)))[-1])
trié (s) -> ['i', 'i', 'i', 'i', 'm', 'p', 'p', 's', 's', 's', 's' ]
tuple (accumuler (trié (s)) -> ('i', 'ii', 'iii', 'iiii', 'iiiim', 'iiiimp', 'iiiimpp', 'iiiimpps', 'iiiimppss', 'iiiimppsss ',' iiiimppssss ')
Nous sélectionnons le dernier index (-1) du tuple
sorted(a)cela renverra une liste triée, donc pour les comparaisons de chaînes, vous n'avez pas besoin de le fairejoin()(voir les réponses de askewchan ci-dessous).