Apakah ada cara mudah untuk mengurutkan huruf dalam string berdasarkan abjad dengan Python?
Sehingga untuk:
a = 'ZENOVW'
Saya ingin kembali:
'ENOVWZ'
Apakah ada cara mudah untuk mengurutkan huruf dalam string berdasarkan abjad dengan Python?
Sehingga untuk:
a = 'ZENOVW'
Saya ingin kembali:
'ENOVWZ'
Jawaban:
Anda dapat melakukan:
>>> a = 'ZENOVW'
>>> ''.join(sorted(a))
'ENOVWZ'
''.join(sorted(a, reverse=True, key=str.lower))
dapat digunakan untuk melakukan jenis case-insensitive terbalik. Bisa jadi berguna.
>>> a = 'ZENOVW'
>>> b = sorted(a)
>>> print b
['E', 'N', 'O', 'V', 'W', 'Z']
sorted
mengembalikan daftar, sehingga Anda dapat membuatnya menjadi string lagi menggunakan join
:
>>> c = ''.join(b)
yang menggabungkan item b
bersama dengan string kosong ''
di antara setiap item.
>>> print c
'ENOVWZ'
Solusi Sorted () dapat memberi Anda beberapa hasil yang tidak terduga dengan string lainnya.
Daftar solusi lain:
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s.lower())))
' belou'
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s)))
' Bbelou'
>>> s = "Bubble Bobble"
>>> ''.join(sorted(s))
' BBbbbbeellou'
Jika Anda ingin menghilangkan ruang di hasilnya, tambahkan fungsi strip () dalam salah satu dari kasus yang disebutkan:
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s.lower()))).strip()
'belou'
Fungsi Python sorted
mengembalikan hasil berbasis ASCII untuk string.
TIDAK BENAR : Dalam contoh di bawah ini, e
dan d
berada di belakang H
dan W
karena itu dengan nilai ASCII.
>>>a = "Hello World!"
>>>"".join(sorted(a))
' !!HWdellloor'
BENAR : Untuk menulis string yang diurutkan tanpa mengubah huruf. Gunakan kode:
>>> a = "Hello World!"
>>> "".join(sorted(a,key=lambda x:x.lower()))
' !deHllloorW'
Jika Anda ingin menghapus semua tanda baca dan angka. Gunakan kode:
>>> a = "Hello World!"
>>> "".join(filter(lambda x:x.isalpha(), sorted(a,key=lambda x:x.lower())))
'deHllloorW'
kode dapat digunakan untuk mengurutkan string dalam urutan abjad tanpa menggunakan fungsi python inbuilt
k = input ("Masukkan string apa saja lagi")
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)
Sangat menyukai jawabannya dengan fungsi reduce (). Berikut cara lain untuk mengurutkan string menggunakan akumulatif ().
from itertools import accumulate
s = 'mississippi'
print(tuple(accumulate(sorted(s)))[-1])
diurutkan (s) -> ['i', 'i', 'i', 'i', 'm', 'p', 'p', 's', 's', 's', 's' ]
tuple (terakumulasi (diurutkan)) -> ('i', 'ii', 'iii', 'iiii', 'iiiim', 'iiiimpp', 'iiiimpp', 'iiiimpps', 'iiiimppss', 'iiiimppss', 'iiiimppsss ',' iiiimppssss ')
Kami memilih indeks terakhir (-1) dari tuple
sorted(a)
akan mengembalikan daftar yang diurutkan, jadi untuk perbandingan string Anda tidak perlujoin()
(lihat jawaban askewchan di bawah).