看似很简单,明明文件夹里面都按照顺序排了,但是程序读取就是一直不按照顺序读!这么解决?!
结局方案如下:1.把文件前面重复内容删除2.删除后重新按照中间数字序号排序
1.去掉前面的重复内容
#导入必要的库
import os
from batchgenerators.utilities.file_and_folder_operations import save_json, subfiles
from typing import Tuple
import numpy as np
folder_path = ''#
import os
for filename in os.listdir(folder_path):
newname = filename.replace('RibFrac', '') #把RibFrac替换成空白
os.rename(folder_path+filename, folder_path+newname)
2.开始排序读取
import os
path=folder_path #待读取的文件夹
path_list=os.listdir(path)#这样可以直接排序,不怕乱了
path_list.sort(key = lambda x :int(x[:-13])) #对读取的路径进行排序,倒数13个开始就是数字了,按这个数字排序
num=1#从1开始编号
for file in path_list:
s = '%03d' % num # 前面补零占位,001,002,003....
os.rename(os.path.join(path, file), os.path.join(path, 'RibFrac_' + str(s) + '.nii.gz'))
num += 1
虽然麻烦了一点,解决问题就行