這篇文章主要介紹“Python如何實現批量自動整理文件”,在日常操作中,相信很多人在Python如何實現批量自動整理文件問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Python如何實現批量自動整理文件”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
為了實現這樣的小工具,我們先設想有下面這些功能。
1、可以自定義整理某一個路徑下面的所有需要被整理的文件。
2、默認情況下,使用文件后綴作為同一種類文件的文件夾名稱,有其他想法的小伙伴可自行擴展。
將使用到的python模塊導入到代碼塊中。
import os # 文件/文件夾應用操作 import shutil # 移動文件 import logging # 使用日志logging來打印日志
選擇好需要整理的原始文件目錄。

下面是整理完成后的效果圖,根據文件類型對各種文件進行整理。

在代碼塊中加入日志打印的模塊,這里日志打印選擇的是logging模塊。
logger = logging.getLogger('自動歸納文件') # 日志名稱
logging.basicConfig(format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s') # 日志打印格式
logger.setLevel(logging.DEBUG) # 日志打印級別下面是文件整理的代碼塊的全部實現方式,主要部分都加上注釋說明。
dir = input('請輸入需要整理的文件目錄: \n') # 需要整理的文件路徑
if os.path.isdir(dir):
logger.info('當前目錄[' + dir + ']校驗成功!')
paths = []
for file_path, dir_names, file_names in os.walk(r'' + dir):
for file_name in file_names:
try:
file_name_path = os.path.join(file_path, file_name)
dir_ = file_name.split('.')[1]
new_file_name_path = os.path.join(dir, dir_)
# 校驗新的文件夾是否已經存在
if os.path.isdir(new_file_name_path):
# 直接移動文件
shutil.move(file_name_path, new_file_name_path)
else:
# 創建好文件夾后移動文件
os.mkdir(new_file_name_path)
shutil.move(file_name_path, new_file_name_path)
paths.append(os.path.join(new_file_name_path, file_name))
except:
logger.error('[' + file_name_path + ']移動發生異常,執行下一個!')
for path in paths:
logger.info('移動完成的文件:' + str(path))
else:
logger.error('輸入的文件夾或者目錄不存在!')以上就是自動整理文件的全部代碼塊的實現部分,使用時依次將代碼塊copy到自己的開發工具中直接啟動就可。
進階
當文件在不同路徑下,又該如何實現批量管理呢,下面是實現的代碼,可以參考一下
import os
import glob
import shutil
'''
@Author: huny
@date: 2020.12.06
@function: 文件整理
'''
class FileType():
def __init__(self):
self.filetype = {
"圖片": [".jpeg", ".jpg", ".tiff", ".gif", ".bmp", ".png", ".bpg", "svg", ".heif", ".psd"],
"視頻": [".avi", ".flv", ".wmv", ".mov", ".mp4", ".webm", ".vob", ".mng", ".qt", ".mpg", ".mpeg", ".3gp", ".mkv"],
"音頻": [".aac", ".aa", ".aac", ".dvf", ".m4a", ".m4b", ".m4p", ".mp3", ".msv", ".ogg", ".oga", ".raw", ".vox", ".wav", ".wma"],
"文檔": [".oxps", ".epub", ".pages", ".docx", ".doc", ".fdf", ".ods", ".odt", ".pwi", ".xsn", ".xps", ".dotx", ".docm", ".dox",
".rvg", ".rtf", ".rtfd", ".wpd", ".xls", ".xlsx", ".ppt", ".pptx", ".csv", ".pdf", ".md",".xmind"],
"壓縮文件": [".a", ".ar", ".cpio", ".iso", ".tar", ".gz", ".rz", ".7z", ".dmg", ".rar", ".xar", ".zip"],
"文本": [".txt", ".in", ".out", ".json","xml",".log"],
"程序腳本": [".py", ".html5", ".html", ".htm", ".xhtml", ".c", ".cpp", ".java", ".css",".sql"],
"可執行程序": [".exe",".bat",".lnk"],
"字體文件": [".ttf", ".OTF", ".WOFF", ".EOT"]
}
def JudgeFile(self, pathname):
for name, type in self.filetype.items():
if pathname in type:
return name
return "無法判斷類型文件"
class DeskTopOrg(object):
def __init__(self):
self.filetype = FileType()
def Organization(self):
filepath = input("請輸入需要整理的文件夾路徑: ")
paths = glob.glob(filepath + "/*.*")
print('paths-->',paths)
for path in paths:
try:
if not os.path.isdir(path):
file = os.path.splitext(path)
filename,type = file
print('type-->',type)
print("filename-->",filename)
print('path-->',path)
dir_path = os.path.dirname(path)
print('dir_path-->',dir_path)
savePath = dir_path + '/{}'.format(self.filetype.JudgeFile(type))
print('savePath-->',savePath)
if not os.path.exists(savePath):
os.mkdir(savePath)
shutil.move(path, savePath)
else:
shutil.move(path, savePath)
except FileNotFoundError:
pass
print("程序執行結束!")
if __name__ == '__main__':
try:
while True:
desktopOrg = DeskTopOrg()
desktopOrg.Organization()
print("---->你的文件已經整理完成。")
a = input('---->請按回車鍵退出:')
if a == '':
break
except BaseException:
print("ERROE:路徑錯誤或有重復的文檔")這樣就可以自由的整理你想要整理的路徑了。
到此,關于“Python如何實現批量自動整理文件”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。