我想知道如何对目录中的文件名进行排序。例如,我有以下名称:
1_00000_6.54.csv
2_00000_1.70.csv
3_00000_1.70.csv
...
10_00000_1.70.csv
11_00000_1.70.csv
...使用下面的python代码,我得到了以下顺序:
def get_pixelist(path):
return [os.path.join(path,f) for f in os.listdir(path) if f.endswith('.csv')]
def group_uniqmz_intensities(path):
pxlist = sorted(get_pixelist(path))提供:
1_00000_6.54.csv
10_00000_1.70.csv
11_00000_1.70
...
2_00000_1.70.csv
...
3_00000_1.70.csv
...我想要之前显示的订单。
发布于 2013-01-30 18:40:23
下面是自然排序的简单实现,假设您的字段都被_拆分
def int_if_possible(s):
try:
return int(s)
except:
return s
>>> sorted(s, key=lambda s: map(int_if_possible, s.split('_')))
['1_00000_6.54.csv',
'2_00000_1.70.csv',
'3_00000_1.70.csv',
'10_00000_1.70.csv',
'11_00000_1.70.csv']此实现利用了列表逐个元素进行比较的事实。如果元素可以转换为整数,我们就将它们作为整数进行比较,否则我们就会回到字符串比较。
编辑:这里介绍了一种更复杂的自然排序解决方案:Natural string sorting。
它非常聪明:它使用正则表达式\d+\D+将输入字符串拆分成交替的数字和非数字。然后按数字比较数字,按字母顺序比较非数字。
https://stackoverflow.com/questions/14601570
复制相似问题