這篇文章主要爲大家詳細介紹了python批量修改文件夾及其子文件夾下的文件內容,具有一定的參考價值,感興趣的小夥伴們可以參考一下
前言:前幾天我看一位同學要修改很多文件中的數據,該文件數據很規律,一行只有三個數,需要將每行最後一個數字改爲負數,但文件有上千個,分佈在每個文件夾下面以及它的多級子文件夾下,看他用excel手動改數據改的很痛苦,我突然想到用Python訪問和操作文件,修改文件內容都很方便,於是在對Python不熟悉的情況下花了大半天寫了下面的程序。
大概思路:先獲取文件夾下所有文件名存在列表中,然後循環遍歷訪問文件內容,修改後寫入新文件,考慮到還有子文件夾,這裏用了遞歸的方法訪問子文件夾的文件,最後修改完再把原文件刪除,將新文件修改爲原文件名,具體程序功能見代碼註釋。
完整代碼:
#coding=utf-8#可加入中文註釋 #函數功能:將指定文件夾下所有文件和子文件夾下的文件遍歷,並修改文件內容 import os fpath ="/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級文件夾及文件內容
修改後文件內容
如果想更改數據後想保留原文件以及修改文件名,可屏蔽代碼中的兩句話
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持神馬文庫。