มีวิธีง่าย ๆ ในการจัดเรียงตัวอักษรในสตริงตามตัวอักษรใน Python หรือไม่?
ดังนั้นสำหรับ:
a = 'ZENOVW'
ฉันอยากจะกลับมา:
'ENOVWZ'
มีวิธีง่าย ๆ ในการจัดเรียงตัวอักษรในสตริงตามตัวอักษรใน Python หรือไม่?
ดังนั้นสำหรับ:
a = 'ZENOVW'
ฉันอยากจะกลับมา:
'ENOVWZ'
คำตอบ:
คุณทำได้:
>>> a = 'ZENOVW'
>>> ''.join(sorted(a))
'ENOVWZ'
''.join(sorted(a, reverse=True, key=str.lower))
สามารถนำมาใช้เพื่อดำเนินการเรียงลำดับกรณีที่ไม่สำคัญ อาจจะมีประโยชน์
>>> a = 'ZENOVW'
>>> b = sorted(a)
>>> print b
['E', 'N', 'O', 'V', 'W', 'Z']
sorted
ส่งคืนรายการเพื่อให้คุณสามารถทำให้มันเป็นสตริงอีกครั้งโดยใช้join
:
>>> c = ''.join(b)
ซึ่งรวมรายการของb
พร้อมกับสตริงว่าง''
ระหว่างแต่ละรายการ
>>> print c
'ENOVWZ'
โซลูชัน Sorted () สามารถให้ผลลัพธ์ที่ไม่คาดคิดกับสตริงอื่น ๆ ได้
รายการโซลูชั่นอื่น ๆ :
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s.lower())))
' belou'
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s)))
' Bbelou'
>>> s = "Bubble Bobble"
>>> ''.join(sorted(s))
' BBbbbbeellou'
หากคุณต้องการกำจัดพื้นที่ในผลลัพธ์ให้เพิ่มฟังก์ชั่น strip () ในกรณีที่กล่าวถึง:
>>> s = "Bubble Bobble"
>>> ''.join(sorted(set(s.lower()))).strip()
'belou'
คุณสามารถใช้ลด
>>> a = 'ZENOVW'
>>> reduce(lambda x,y: x+y, sorted(a))
'ENOVWZ'
ฟังก์ชัน Pythonsorted
ส่งคืนผลลัพธ์ตาม ASCII สำหรับสตริง
INCORRECT : ในตัวอย่างด้านล่างe
และd
อยู่ข้างหลังH
และW
ครบตามค่า ASCII
>>>a = "Hello World!"
>>>"".join(sorted(a))
' !!HWdellloor'
การแก้ไข : เพื่อที่จะเขียนสตริงที่เรียงลำดับโดยไม่ต้องเปลี่ยนตัวพิมพ์ของตัวอักษร ใช้รหัส:
>>> a = "Hello World!"
>>> "".join(sorted(a,key=lambda x:x.lower()))
' !deHllloorW'
หากคุณต้องการลบเครื่องหมายวรรคตอนและตัวเลขทั้งหมด ใช้รหัส:
>>> a = "Hello World!"
>>> "".join(filter(lambda x:x.isalpha(), sorted(a,key=lambda x:x.lower())))
'deHllloorW'
รหัสสามารถใช้ในการเรียงลำดับสตริงตามตัวอักษรโดยไม่ต้องใช้ฟังก์ชั่น inbuilt ใด ๆ ของหลาม
k = อินพุต ("ป้อนสตริงใด ๆ อีกครั้ง")
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)
ชอบคำตอบด้วยฟังก์ชั่นลด () นี่เป็นอีกวิธีในการเรียงลำดับสตริงโดยใช้ accumulate ()
from itertools import accumulate
s = 'mississippi'
print(tuple(accumulate(sorted(s)))[-1])
เรียงลำดับ -> ['i', 'i', 'i', 'i', 'm', 'p', 'p', 's', 's', 's', 's' ]
tuple (สะสม (เรียงลำดับ)) -> ('i', 'ii', 'iii', 'iiii', 'iiiim', 'iiiimpp', 'iiiimpps', 'iiiimppss', 'iiiimppss' ',' iiiimppssss ')
เรากำลังเลือกดัชนีสุดท้าย (-1) ของ tuple
sorted(a)
จะกลับรายการที่เรียงลำดับดังนั้นสำหรับการเปรียบเทียบสตริงคุณไม่จำเป็นต้องjoin()
(ดูคำตอบ askewchan ที่ด้านล่าง)