Python實(shí)現(xiàn)批量將符合要求的文件自動(dòng)復(fù)制到新文件夾
本文介紹基于Python語言,讀取一個(gè)文件夾,并將其中每一個(gè)子文件夾內(nèi)符合名稱要求的文件加以篩選,并將篩選得到的文件復(fù)制到另一個(gè)目標(biāo)文件夾中的方法。
本文的需求是:現(xiàn)在有一個(gè)大的文件夾,其中含有多個(gè)子文件夾,如下圖所示。
對(duì)于其中的每一個(gè)子文件夾,都含有大量的文件;例如,我們就打開上圖中的2021文件夾,得到結(jié)果如下圖所示。
我們的需求是,希望基于每一個(gè)子文件夾內(nèi)的每一個(gè)文件,將文件名稱中含有指定字段的文件提取出來——在本文中,我們就希望提取得到文件名稱中含有STB字段的,也就是上圖紫色框內(nèi)出現(xiàn)STB的文件是我們需要的。提取到全部符合要求的文件后,我們還需要將這些文件都復(fù)制到另一個(gè)目標(biāo)文件夾中。
明確了需求,接下來就可以開始代碼的撰寫。本文所用到的代碼如下所示。
#!/usr/bin/env python3 # -*- coding: utf-8 -*- """ Created on Mon Oct 2 12:48:49 2023 @author: fkxxgis """ import os import shutil source_folder = "/media/dell/H30-35/GF_SR" target_folder = "/media/dell/H30-35/GF_SR/STB" if not os.path.exists(target_folder): os.makedirs(target_folder) year_folders = [f for f in os.listdir(source_folder) if os.path.isdir(os.path.join(source_folder, f))] for year_folder in year_folders: if year_folder == "STB": continue year_folder_path = os.path.join(source_folder, year_folder) for file_name in os.listdir(year_folder_path): if "STB" in file_name: source_file = os.path.join(year_folder_path, file_name) target_file = os.path.join(target_folder, file_name) shutil.copy(source_file, target_file)
其中,我們導(dǎo)入了os和shutil模塊,它們都提供了處理文件和目錄的功能;同時(shí),我們定義了源文件夾路徑source_folder(也就是存儲(chǔ)有多個(gè)子文件夾的文件夾路徑)和目標(biāo)文件夾路徑target_folder(也就是最終結(jié)果存放的路徑)。
隨后,我們使用os.makedirs()函數(shù)檢查目標(biāo)文件夾是否存在,如果不存在則創(chuàng)建它。接下來,我們使用列表推導(dǎo)式生成一個(gè)包含源文件夾中所有子文件夾的列表year_folders;其中,我們使用了os.listdir()函數(shù)獲取源文件夾中的所有文件和文件夾,并使用os.path.isdir()函數(shù)判斷是否為文件夾。
接下來,我們就開始遍歷每個(gè)子文件夾。首先,需要注意的是,我們要檢查當(dāng)前遍歷的子文件夾是否為我們的目標(biāo)文件夾路徑STB;如果是,則跳過該子文件夾的處理——這一步驟是防止我們用來存放結(jié)果的目標(biāo)文件夾也被遍歷,否則就會(huì)出現(xiàn)文件復(fù)制沖突。
其次,構(gòu)建當(dāng)前遍歷的子文件夾的完整路徑y(tǒng)ear_folder_path,并使用os.listdir()函數(shù)獲取子文件夾中的所有文件。隨后,再遍歷剛剛得到的子文件夾中的每個(gè)文件——如果文件名包含STB,那么這個(gè)文件就是我們需要的文件;我們就構(gòu)建源文件(待復(fù)制的文件)的完整路徑source_file和目標(biāo)文件(預(yù)計(jì)復(fù)制完畢的文件)的完整路徑target_file,并緊接著使用shutil.copy()函數(shù)將源文件復(fù)制到目標(biāo)文件。
通過這樣的遍歷,我們就能夠?qū)⒃次募A路徑source_folder中全部含有STB字段的文件復(fù)制到我們的目標(biāo)文件夾中了。
執(zhí)行上述代碼,即可在我們的目標(biāo)文件夾中看到全部含有STB字段的文件,如下圖所示。
到此這篇關(guān)于Python實(shí)現(xiàn)批量將符合要求的文件自動(dòng)復(fù)制到新文件夾的文章就介紹到這了,更多相關(guān)python批量復(fù)制文件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python實(shí)現(xiàn)合并兩個(gè)列表的方法分析
這篇文章主要介紹了Python實(shí)現(xiàn)合并兩個(gè)列表的方法,結(jié)合實(shí)例形式對(duì)比分析了常見的Python列表合并操作技巧,需要的朋友可以參考下2018-05-05快速進(jìn)修Python指南之網(wǎng)絡(luò)編程及并發(fā)編程
這篇文章主要為大家介紹了Java開發(fā)者如何快速進(jìn)修Python指南之網(wǎng)絡(luò)編程及并發(fā)編程實(shí)例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12Python 使用 multiprocessing 模塊創(chuàng)建進(jìn)程池的操作方法
在現(xiàn)代計(jì)算任務(wù)中,尤其是處理大量數(shù)據(jù)或計(jì)算密集型任務(wù)時(shí),使用并行處理可以顯著提升程序性能,Python的multiprocessing模塊提供了創(chuàng)建進(jìn)程池的功能,通過預(yù)先創(chuàng)建的進(jìn)程來并發(fā)執(zhí)行任務(wù),避免了頻繁的進(jìn)程創(chuàng)建和銷毀,感興趣的朋友一起看看吧2024-10-10Pandas刪除數(shù)據(jù)的幾種情況(小結(jié))
這篇文章主要介紹了Pandas刪除數(shù)據(jù)的幾種情況(小結(jié)),詳細(xì)的介紹了4種方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06Python遍歷zip文件輸出名稱時(shí)出現(xiàn)亂碼問題的解決方法
這篇文章主要介紹了Python遍歷zip文件輸出名稱時(shí)出現(xiàn)亂碼問題的解決方法,實(shí)例分析了Python亂碼的出現(xiàn)的原因與相應(yīng)的解決方法,需要的朋友可以參考下2015-04-04Python實(shí)現(xiàn)將羅馬數(shù)字轉(zhuǎn)換成普通阿拉伯?dāng)?shù)字的方法
這篇文章主要介紹了Python實(shí)現(xiàn)將羅馬數(shù)字轉(zhuǎn)換成普通阿拉伯?dāng)?shù)字的方法,簡單分析了羅馬數(shù)字的構(gòu)成并結(jié)合實(shí)例形式給出了Python轉(zhuǎn)換羅馬數(shù)字為阿拉伯?dāng)?shù)字的實(shí)現(xiàn)方法,需要的朋友可以參考下2017-04-04