在Python中是否有一种简单的方法来按字母顺序对字符串中的字母进行排序?
所以对于:
a = 'ZENOVW'
我想回复:
'ENOVWZ'
在Python中是否有一种简单的方法来按字母顺序对字符串中的字母进行排序?
所以对于:
a = 'ZENOVW'
我想回复:
'ENOVWZ'
当前回答
你可以用reduce
>>> a = 'ZENOVW'
>>> reduce(lambda x,y: x+y, sorted(a))
'ENOVWZ'
其他回答
你可以:
>>> a = 'ZENOVW'
>>> ''.join(sorted(a))
'ENOVWZ'
>>> a = 'ZENOVW'
>>> b = sorted(a)
>>> print b
['E', 'N', 'O', 'V', 'W', 'Z']
Sorted返回一个列表,所以你可以再次使用join使它成为一个字符串:
>>> c = ''.join(b)
它将b中的项连接在一起,每项之间都有一个空字符串”。
>>> print c
'ENOVWZ'
非常喜欢reduce()函数的答案。下面是使用accumulate()对字符串进行排序的另一种方法。
from itertools import accumulate
s = 'mississippi'
print(tuple(accumulate(sorted(s)))[-1])
排序(s) - >(“我”、“我”、“我”,“我”,“m”,“p”,“p”,‘s’,‘s’,‘s’,' s ']
两倍(累积)-> (' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' ',' '
我们正在选择元组的最后一个索引(-1)
你可以用reduce
>>> a = 'ZENOVW'
>>> reduce(lambda x,y: x+y, sorted(a))
'ENOVWZ'
该代码可用于按字母顺序对字符串排序,而无需使用任何python内置函数
k = input("再次输入任意字符串")
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)