我有一个字符串列表,大致如下所示:list = ['file.t00Z.wrff02.grib2', 'file.t00Z.wrff03.grib2', 'file.t00Z.wrff00.grib2',
'file.t00Z.wrff05.grib2', 'file.t00Z.wrff04.grib2', 'file.t00Z.wrff01.grib2',
'file.t06Z.wrff01.grib2', 'file.t06Z.wrff00.grib2', 'file.t06Z.wrff02.grib2', ...]
我最近问了一个问题here,在这个问题中,我学会了如何使用lambda函数按子字符串对字符串列表进行排序:
list.sort(key=lambda x: x[x.find('wrff'):])
现在我需要知道一个主关键字的排序方式。我想先按“file.t”后面的两位数字,然后按“wrff”后面的两位数字对文件进行排序。有没有一种方法可以同时执行这两种操作?在
解决方案:我最终使用了用户Moses Koledoye在下面推荐的两元组lambda函数sort,但在尝试将此排序过程应用于具有不同命名约定的文件名组时遇到了问题。在
在我的脚本中,我有3个Python对象,它们从唯一的数据目录中获取文件并形成一个包含这些文件的列表(如上面的一个)。每个对象都使用不同的命名约定获取文件,每个不同的文件组在它们的名称中有不同数量的数字组。在
为了在不增加复杂性的情况下处理这个问题,我决定使用用户jaredgougen建议的natsort模块,它工作得非常好。在