前言:前幾天我看一位同學要修改很多文件中的數據,該文件數據很規律,一行只有三個數,需要將每行最后一個數字改為負數,但文件有上千個,分布在每個文件夾下面以及它的多級子文件夾下,看他用excel手動改數據改的很痛苦,我突然想到用Python訪問和操作文件,修改文件內容都很方便,于是在對Python不熟悉的情況下花了大半天寫了下面的程序。
大概思路:先獲取文件夾下所有文件名存在列表中,然后循環遍歷訪問文件內容,修改后寫入新文件,考慮到還有子文件夾,這里用了遞歸的方法訪問子文件夾的文件,最后修改完再把原文件刪除,將新文件修改為原文件名,具體程序功能見代碼注釋。
完整代碼:
#coding=utf-8#可加入中文注釋#函數功能:將指定文件夾下所有文件和子文件夾下的文件遍歷,并修改文件內容import osfpath ="/home/hyj/桌面/files_1"#這里是你的第一級文件夾的路徑def filechanger(path): filenames = os.listdir(path)#將path路徑下的所有文件名存入列表filenames for filename in filenames:#循環遍歷每個文件 domain = os.path.abspath(path)#獲取規范的路徑 filename = os.path.join(domain,filename)#帶路徑的文件名 if os.path.isdir(filename): # 如果是文件夾進入遞歸 filechanger(filename) continue fread = open(filename,'r') fwrite = open("%s.backup"%filename,'w') while True:#修改文件內容 line=fread.readline()#按行讀取內容 if len(line)>0:#當改行為空,表明已經讀取到文件末尾,退出循環 content = line.split()#因為每行有三個TAB符號分開的數字,將它們分開 print(content) content[2] = '-'+content[2] print(content) newcont = content[0]+'/t'+content[1]+'/t'+content[2]+'/r' fwrite.write(newcont)#修改后寫入新文件 else: break fread.close() fwrite.close() os.remove(filename)#如果想更改數據后想保留原文件以及修改文件名可屏蔽這一句和下一句 os.rename("%s.backup" % filename, filename)#filechanger(fpath)修改前
第1級文件夾及文件內容
第2級文件夾及文件內容
第3級文件夾及文件內容
修改后文件內容
如果想更改數據后想保留原文件以及修改文件名,可屏蔽代碼中的兩句話
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。
新聞熱點
疑難解答