Python 如何对字符串列表进行排序?
在Python中创建按字母顺序排序的列表的最佳方法是什么Python 如何对字符串列表进行排序?,python,string,sorting,Python,String,Sorting,在Python中创建按字母顺序排序的列表的最佳方法是什么 list.sort() 其实很简单:)基本答案: mylist = ["b", "C", "A"] mylist.sort() 这将修改原始列表(即,就地排序)。要获取列表的已排序副本,而不更改原始副本,请使用以下功能: for x in sorted(mylist): print x for x in sorted(list): print x 然而,上面的例子有点幼稚,因为它们不考虑区域设置,并且执行区分大小写
list.sort()
其实很简单:)基本答案:
mylist = ["b", "C", "A"]
mylist.sort()
这将修改原始列表(即,就地排序)。要获取列表的已排序副本,而不更改原始副本,请使用以下功能:
for x in sorted(mylist):
print x
for x in sorted(list):
print x
然而,上面的例子有点幼稚,因为它们不考虑区域设置,并且执行区分大小写的排序。您可以利用可选参数key
来指定自定义排序顺序(使用cmp
的替代方案是一种不推荐的解决方案,因为它需要多次求值-key
每个元素只计算一次)
因此,要根据当前区域设置进行排序,并考虑特定于语言的规则(是functools中的一个辅助函数):
最后,如果需要,可以指定用于排序的:
import locale
locale.setlocale(locale.LC_ALL, 'en_US.UTF-8') # vary depending on your lang/locale
assert sorted((u'Ab', u'ad', u'aa'),
key=cmp_to_key(locale.strcoll)) == [u'aa', u'Ab', u'ad']
最后注意:您将看到使用lower()
方法的不区分大小写排序示例-这些方法不正确,因为它们仅适用于ASCII字符子集。对于任何非英语数据来说,这两个都是错误的:
# this is incorrect!
mylist.sort(key=lambda x: x.lower())
# alternative notation, a bit faster, but still wrong
mylist.sort(key=str.lower)
但这如何处理特定于语言的排序规则呢?它考虑了语言环境吗
否,
list.sort()
是一个通用排序函数。如果要根据Unicode规则进行排序,则必须定义自定义排序键函数。您可以尝试使用该模块,但我不知道它有多完整。还值得注意其功能:
for x in sorted(mylist):
print x
for x in sorted(list):
print x
这将返回列表的新排序版本,而不更改原始列表。对字符串进行排序的正确方法是:
import locale
locale.setlocale(locale.LC_ALL, 'en_US.UTF-8') # vary depending on your lang/locale
assert sorted((u'Ab', u'ad', u'aa'), cmp=locale.strcoll) == [u'aa', u'Ab', u'ad']
# Without using locale.strcoll you get:
assert sorted((u'Ab', u'ad', u'aa')) == [u'Ab', u'aa', u'ad']
前面的示例mylist.sort(key=lambda x:x.lower())
适用于仅ASCII的上下文。假设s=“ZWzaAd”
要在字符串上方排序,简单的解决方案将在1下方
print ''.join(sorted(s))
请在Python3中使用sorted()函数
items = ["love", "like", "play", "cool", "my"]
sorted(items2)
或者可能:
旧问题,但如果您想在不设置
locale.LC_ALL
的情况下执行区域设置感知排序,您可以按照以下建议使用:
import icu#PyICU
def排序字符串(字符串,区域设置=无):
如果区域设置为“无”:
返回排序(字符串)
collator=icu.collator.createInstance(icu.Locale(Locale))
返回排序(字符串,key=collator.getSortKey)
然后打电话,例如:
new\u list=已排序的字符串(字符串列表,“de\u de.utf8”)
这在不安装任何区域设置或更改其他系统设置的情况下对我有效
(这已经被提出了,但我想让它更加突出,因为一开始我自己也错过了。)
结果
['abc','ba','cd','dc','xy']
这很简单:
分数=分数。拆分(',')
对于排序中的x(分数):
打印(x)
mylist.sort(key=str.lower)
更快。这一点很好。我将保留我当前的示例,因为初学者可能更容易看到发生了什么,但我会在将来记住这一点。如果有人好奇,可以在@BornToCode:1-找到list.sort()的性能。看看修订版(2008)我的评论回复(我的评论是关于不必要地使用lambda)。2-对非ASCII字符进行排序是一个很大的独立主题。而不是基于区域设置的解决方案。@Dmitry这是因为您正在打印在[1,2,3].sort()中调用的排序函数的返回值。由于sort()
对列表进行就地排序(即直接更改列表),因此它不会返回已排序的列表,实际上也不会返回任何内容,因此打印语句将打印None
。如果您将列表保存到一个变量中,例如x
,称为x.sort()
,然后print(x)
,您将看到已排序的列表。使用locale
和它的字符串排序方法可以根据当前的区域设置自然排序。这里不是您正在排序的字符串列表
l =['abc' , 'cd' , 'xy' , 'ba' , 'dc']
l.sort()
print(l1)
scores = '54 - Alice,35 - Bob,27 - Carol,27 - Chuck,05 - Craig,30 - Dan,27 - Erin,77 - Eve,14 - Fay,20 - Frank,48 - Grace,61 - Heidi,03 - Judy,28 - Mallory,05 - Olivia,44 - Oscar,34 - Peggy,30 - Sybil,82 - Trent,75 - Trudy,92 - Victor,37 - Walter'