我想知道如何对目录中的文件名进行排序。例如,我有以下名称:
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:28:25
最简单的方法是在排序时将文件名填零:
def group_uniqmz_intensities(path):
pxlist = sorted(get_pixelist(path), key=lambda f: f.rjust(17, '0'))在排序时,它会用0字符将每个文件名填充到17个字符;因此,将1_00000_6.54.csv填充到01_00000_6.54.csv中,而将10_00000_1.70.csv保留为原样。在词法上,01在10之前排序。
我选择17作为硬编码值,以简化操作;您可以使用下面的代码自动找到所需的值:
def group_uniqmz_intensities(path):
padsize = max(len(f) for f in pxlist)
pxlist = sorted(get_pixelist(path), key=lambda f: f.rjust(padsize, '0'))发布于 2013-01-30 18:32:45
由于'1‘< '_’,你得到的是第二个排序。你可以通过给sorted一个key-function来实现你的目标:
def group_uniqmz_intensities(path):
pxlist = sorted(get_pixelist(path), key=lambda x: int(x.split("_")[0]))请确保您的所有文件都遵循相同的命名方案({ ValueError }_{rest}编号),否则将出现编号。
编辑: Martijn提供了一个更优雅的解决方案。
发布于 2013-01-30 18:37:46
基于字母数字排序的this answer:
def group_uniqmz_intensities(path):
pxlist = sorted(get_pixelist(path), key=lambda filename: int(filename.partition('_')[0]))https://stackoverflow.com/questions/14601570
复制相似问题