Python自然排序
我有一些文件需要按名称排序,不幸的是我不能使用常规排序,因为我还想对字符串中的数字进行排序,所以我做了一些研究,发现我要找的是所谓的Python自然排序,python,regex,sorting,natural-sort,Python,Regex,Sorting,Natural Sort,我有一些文件需要按名称排序,不幸的是我不能使用常规排序,因为我还想对字符串中的数字进行排序,所以我做了一些研究,发现我要找的是所谓的自然排序 我尝试了给出的解决方案,效果非常好 但是,对于像PresserInc-1_10.jpg和PresserInc-1_11.jpg这样的字符串,它会导致特定的自然键算法失败,因为它只匹配第一个整数,在这种情况下,第一个整数将是1和1,因此它会放弃排序。因此,我认为可能会有帮助的是匹配字符串中的所有数字并将它们组合在一起,因此如果我有PresserInc-1_1
自然排序
我尝试了给出的解决方案,效果非常好
但是,对于像PresserInc-1_10.jpg
和PresserInc-1_11.jpg
这样的字符串,它会导致特定的自然键算法失败,因为它只匹配第一个整数,在这种情况下,第一个整数将是1
和1
,因此它会放弃排序。因此,我认为可能会有帮助的是匹配字符串中的所有数字并将它们组合在一起,因此如果我有PresserInc-1_11.jpg
算法应该返回111
,所以我的问题是,这可能吗
以下是文件名列表:
files=['PresserInc-1.jpg'、'PresserInc-1_10.jpg'、'PresserInc-1_11.jpg'、'PresserInc-10.jpg'、'PresserInc-2.jpg'、'PresserInc-3.jpg'、'PresserInc-4.jpg'、'PresserInc-5.jpg'、'PresserInc-6.jpg'、'PresserInc-11.jpg']
:您链接到的页面
但不要就此止步强>
:杰夫·阿特伍德(Jeff Atwood)的博客解释了如何正确操作
:我根据杰夫·阿特伍德的博客发布的答案
下面是答案中的代码:
import re
def natural_sort(l):
convert = lambda text: int(text) if text.isdigit() else text.lower()
alphanum_key = lambda key: [convert(c) for c in re.split('([0-9]+)', key)]
return sorted(l, key=alphanum_key)
您的数据的结果:
PresserInc-1.jpg
PresserInc-1_10.jpg
PresserInc-1_11.jpg
PresserInc-2.jpg
PresserInc-3.jpg
etc...
PresserInc-1.jpg
按C-1_10.jpg
PresserInc-1_11.jpg
PresserInc-2.jpg
PresserInc-3.jpg
等
在线查看:如果您不介意使用第三方库,您可以使用来实现这一点
>>> import natsort
>>> files = ['PresserInc-1.jpg', 'PresserInc-1_10.jpg', 'PresserInc-1_11.jpg', 'PresserInc-10.jpg', 'PresserInc-2.jpg', 'PresserInc-3.jpg', 'PresserInc-4.jpg', 'PresserInc-5.jpg', 'PresserInc-6.jpg', 'PresserInc-11.jpg']
>>> natsort.natsorted(files)
['PresserInc-1.jpg',
'PresserInc-1_10.jpg',
'PresserInc-1_11.jpg',
'PresserInc-2.jpg',
'PresserInc-3.jpg',
'PresserInc-4.jpg',
'PresserInc-5.jpg',
'PresserInc-6.jpg',
'PresserInc-10.jpg',
'PresserInc-11.jpg']
我不明白你的问题…请发布一个更清晰的输入和预期的输出在
key=alphanum\u key
pleaseThanks中没有空格,你是对的,不应该停在那里:),尽管有点累。。谢谢:)