Bir dizedeki harfleri Python'da alfabetik olarak sıralamanın kolay bir yolu var mı?
İçin böylece:
a = 'ZENOVW'
Dönmek isterim:
'ENOVWZ'
Bir dizedeki harfleri Python'da alfabetik olarak sıralamanın kolay bir yolu var mı?
İçin böylece:
a = 'ZENOVW'
Dönmek isterim:
'ENOVWZ'
Yanıtlar:
Yapabilirsin:
>>> a = 'ZENOVW'
>>> ''.join(sorted(a))
'ENOVWZ'
''.join(sorted(a, reverse=True, key=str.lower))Tersine büyük / küçük harfe duyarlı olmayan bir sıralama gerçekleştirmek için kullanılabileceğini unutmayın . Kullanışlı olabilir.
Sorted () çözümü size diğer dizelerle beklenmedik sonuçlar verebilir.
Diğer çözümlerin listesi:
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s.lower())))
' belou'
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s)))
' Bbelou'
>>> s = "Bubble Bobble"
>>> ''.join(sorted(s))
' BBbbbbeellou'
Sonuçtaki alandan kurtulmak istiyorsanız, belirtilen durumlardan birine strip () işlevi ekleyin:
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s.lower()))).strip()
'belou'
Python işlevi sorteddize için ASCII tabanlı sonuç döndürür.
YANLIŞ : Aşağıdaki örnekte eve darkasında Hve WASCII değeri nedeniyle.
>>>a = "Hello World!"
>>>"".join(sorted(a))
' !!HWdellloor'
DÜZELT : Harf büyüklüğünü değiştirmeden sıralanan dizeyi yazmak için . Kodu kullanın:
>>> a = "Hello World!"
>>> "".join(sorted(a,key=lambda x:x.lower()))
' !deHllloorW'
Tüm noktalama işaretlerini ve sayıları kaldırmak istiyorsanız. Kodu kullanın:
>>> a = "Hello World!"
>>> "".join(filter(lambda x:x.isalpha(), sorted(a,key=lambda x:x.lower())))
'deHllloorW'
kod, python'un herhangi bir dahili işlevini kullanmadan dizeyi alfabetik olarak sıralamak için kullanılabilir
k = giriş ("Herhangi bir dizgiyi tekrar girin")
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)
Reduce () fonksiyonu ile cevabı gerçekten beğendim. Dizeyi accumulate () kullanarak sıralamanın başka bir yolu.
from itertools import accumulate
s = 'mississippi'
print(tuple(accumulate(sorted(s)))[-1])
sıralanmış (s) -> ['i', 'i', 'i', 'i', 'm', 'p', 'p', 's', 's', 's', 's' ]
demet (birikir (sıralanır)) -> ('i', 'ii', 'iii', 'iiii', 'iiiim', 'iiiimp', 'iiiimpp', 'iiiimpps', 'iiiimppss', 'iiiimppsss ',' iiiimppssss ')
Grubun son dizinini (-1) seçiyoruz
sorted(a)bir liste döndüreceğini unutmayın , bu nedenle dize karşılaştırmaları için gerekmemektedirjoin()(aşağıdaki soru cevap bölümüne bakınız).