首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >按特定顺序对文件进行排序

按特定顺序对文件进行排序
EN

Stack Overflow用户
提问于 2013-01-30 18:20:00
回答 4查看 264关注 0票数 2

我想知道如何对目录中的文件名进行排序。例如,我有以下名称:

代码语言:javascript
复制
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代码,我得到了以下顺序:

代码语言:javascript
复制
 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))

提供:

代码语言:javascript
复制
1_00000_6.54.csv
10_00000_1.70.csv
11_00000_1.70
...
2_00000_1.70.csv
...
3_00000_1.70.csv
...

我想要之前显示的订单。

EN

回答 4

Stack Overflow用户

发布于 2013-01-30 18:28:25

最简单的方法是在排序时将文件名填零:

代码语言:javascript
复制
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保留为原样。在词法上,0110之前排序。

我选择17作为硬编码值,以简化操作;您可以使用下面的代码自动找到所需的值:

代码语言:javascript
复制
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'))
票数 2
EN

Stack Overflow用户

发布于 2013-01-30 18:32:45

由于'1‘< '_’,你得到的是第二个排序。你可以通过给sorted一个key-function来实现你的目标:

代码语言:javascript
复制
 def group_uniqmz_intensities(path):
     pxlist = sorted(get_pixelist(path), key=lambda x: int(x.split("_")[0]))

请确保您的所有文件都遵循相同的命名方案({ ValueError }_{rest}编号),否则将出现编号。

编辑: Martijn提供了一个更优雅的解决方案。

票数 0
EN

Stack Overflow用户

发布于 2013-01-30 18:37:46

基于字母数字排序的this answer

代码语言:javascript
复制
def group_uniqmz_intensities(path):
    pxlist = sorted(get_pixelist(path), key=lambda filename: int(filename.partition('_')[0]))
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14601570

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档