下面為大家分享一篇python讀取檔案名稱產生list的方法,具有很好的參考價值,希望對大家有所協助。一起過來看看吧
經常需要讀取某個檔案夾下所有的影像檔。
我使用python寫了個簡單的代碼,讀取某個檔案夾下某個尾碼的檔案,將檔案名稱產生為文本(csv格式)
import fnmatchimport osimport pandas as pdimport numpy as np import sysInputStra = sys.argv[1]InputStrb = sys.argv[2]def ReadSaveAddr(Stra,Strb): #print(Stra) #print(Strb) print("Read :",Stra,Strb) a_list = fnmatch.filter(os.listdir(Stra),Strb) print("Find = ",len(a_list)) df = pd.DataFrame(np.arange(len(a_list)).reshape((len(a_list),1)),columns=['Addr']) df.Addr = a_list #print(df.head()) df.to_csv('Get.lst',columns=['Addr'],index=False,header=False) print("Write To Get.lst !")ReadSaveAddr(InputStra,InputStrb)
上面代碼儲存為:GetLst.py
使用時:
在cmd視窗輸入:
python GetLst.py F:/train/pos *.png
發現上面代碼不能深入到下一層目錄,又做了點修改:
def ReadSaveAddr2(Stra,Strb): df = pd.DataFrame(np.arange(0).reshape(0,1),columns=['Addr']) print(df) path = InputStra for dirpath,dirnames,filenames in os.walk(path): #for filename in filenames: a_list = fnmatch.filter(os.listdir(dirpath),Strb) if len(a_list): dft = pd.DataFrame(np.arange(len(a_list)).reshape((len(a_list),1)),columns=['Addr']) dft.Addr = a_list dft.Addr = dirpath + '\\' + dft.Addr#輸出絕對路徑 frames = [df,dft] df = pd.concat(frames) print(df.shape) df.to_csv('Get.lst',columns='Addr'],index=False,header=False) print("Write To Get.lst !")