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中没有空格,你是对的,不应该停在那里:),尽管有点累。。谢谢:)