方法 1

>>> import os
>>> fileList = os.listdir('TestDir')
>>> fileList
['test1.txt', 'test10.txt', 'test11.txt', 'test2.txt', 'test23.txt', 'test28.txt']
>>> fileList.sort(key= lambda x:int(x[4:-4]))
>>> fileList
['test1.txt', 'test2.txt', 'test10.txt', 'test11.txt', 'test23.txt', 'test28.txt']
>>>

方法 2

>>> import os
>>> import natsort
>>> fileList = os.listdir('TestDir')
>>> fileList
['test1.txt', 'test10.txt', 'test11.txt', 'test2.txt', 'test23.txt', 'test28.txt']
>>> fileList = natsort.natsorted(fileList)
>>> fileList
['test1.txt', 'test2.txt', 'test10.txt', 'test11.txt', 'test23.txt', 'test28.txt']
>>>

sort()和natsort()的区别

sort()后是1、10、11、2、3、4…而natsort()结果是1,2,3…10,11

参考Python 获取目录下的文件列表,并自然排序

方法3

import re
file_list = os.listdir(file_path)
file_list = sorted(file_list,key = lambda i:int(re.match(r'(\d+)',i).group()))

输出:

file_list: ['1.csv',  '5.csv', '6.csv', '9.csv', '10.csv', '11.csv',...]

参考Python–列表中字符串按照某种规则排序的方法