我有一些文件需要按名称排序,不幸的是我不能使用常规排序,因为我也想对字符串中的数字进行排序,所以我做了一些研究,发现我正在寻找的是什么natural sorting
.
我尝试了这里给出的解决方案,它完美地工作.
然而,对于像串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']