Python自然排序

Pau*_*ulo 4 python regex sorting natural-sort

我有一些文件需要按名称排序,不幸的是我不能使用常规排序,因为我也想对字符串中的数字进行排序,所以我做了一些研究,发现我正在寻找的是什么natural sorting.

我尝试了这里给出的解决方案,它完美地工作.

然而,对于像串PresserInc-1_10.jpgPresserInc-1_11.jpg导致特定的自然密钥算法失败,因为它仅匹配在这种情况下将是第一个整11,所以它抛出了排序.所以我认为可能有帮助的是匹配字符串中的所有数字并将它们组合在一起,所以如果我有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']

Mar*_*ers 8

谷歌:Python自然排序.

结果1:您链接到的页面.

但不要止步不前!

结果2:Jeff Atwood的博客解释了如何正确地完成它.

结果3:我根据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)
Run Code Online (Sandbox Code Playgroud)

您的数据结果:

PresserInc-1.jpg
PresserInc-1_10.jpg
PresserInc-1_11.jpg
PresserInc-2.jpg
PresserInc-3.jpg
etc...

看到它在线工作:ideone