Python基于面向?qū)ο笞鲆粋€(gè)文件夾整理工具
此前曾經(jīng)基于函數(shù)實(shí)現(xiàn)過這個(gè)功能:用Python做一個(gè)文件夾整理工具。這次基于面向?qū)ο蟮姆椒?,重新?shí)現(xiàn)這個(gè)小工具。
本文中提到的FileSystem,來自于這里:Python根據(jù)文件后綴整理文件夾
目標(biāo)
我們的目的是做一個(gè)像下面這樣的工具,前面兩個(gè)輸入框,用于輸入源路徑和目標(biāo)就,下面的圖片、視頻、音樂表示在目標(biāo)路徑中創(chuàng)建的文件夾,后面的文件后綴,表示將這類文件移動(dòng)到對(duì)應(yīng)的文件夾中,加減號(hào)可以新增或刪除文件夾。
文件夾對(duì)話框
第一步,實(shí)現(xiàn)源路徑和目標(biāo)路徑的輸入輸出,從而需要自定義一個(gè)組件,代碼如下
import tkinter as tk import tkinter.ttk as ttk from tkinter.filedialog import (askopenfilename, askopenfilenames, askdirectory, asksaveasfilename) from tkinter.colorchooser import askcolor class DialogButton(ttk.Frame): def __init__(self, master, height, widthL, widthR, logtype, label=None, text=None, frmDct={}, btnDct={}, enyDct={}, logDct={}): w = widthL + widthR super().__init__(master, height=height, width = w, **frmDct) self.pack(fill=tk.X) self.text = tk.StringVar() if not text else text ttk.Entry(self, width=widthL, textvariable=self.text, **enyDct).pack(side=tk.LEFT, fill = tk.X, expand=True) ttk.Button(self, width=widthR, text=self.setLabel(logtype, label), command = self.Click, **btnDct).pack(side=tk.RIGHT, padx=5) self.logtype = logtype self.logDct = logDct def setLabel(self, key, label=None): if label: return label labelDct = { "文件" : "選擇文件", "文件夾" : "選擇路徑", "多文件" : "選擇多個(gè)文件", "保存" : "存儲(chǔ)路徑", "顏色" : "選擇顏色", } return labelDct[key] def Click(self): typeDct = { "文件" : askopenfilename, "文件夾": askdirectory, "多文件": askopenfilenames, "保存" : asksaveasfilename, "顏色" : askcolor, } text = typeDct[self.logtype](**self.logDct) if self.logtype == "顏色": text = text[1] self.text.set(text) def get(self): return self.text.get() def set(self, txt): self.text.set(txt)
文件映射組件
在文件映射列表中,每一行的UI元素是完全相同的,故而可以新建一個(gè)文件映射組件,文件映射組件,主要由左右兩部分組成,左側(cè)是文件夾名,右側(cè)是對(duì)應(yīng)的文件后綴。從這兩個(gè)子組件出發(fā),可以為其設(shè)置初始化參數(shù)以及方法。先看源碼,再逐段解析
class ExFolder(ttk.Frame): def __init__(self, master, folder=None, ex=None, **options): super().__init__(master, **options) self.pack() self.folder = tk.StringVar() if folder : self.setFolder(folder) self.ex = tk.StringVar() if ex : self.setEx(ex) self.initWidgets() def initWidgets(self): ttk.Entry(self, textvariable=self.folder, width=10).pack(side=tk.LEFT, padx=2) ttk.Entry(self, textvariable=self.ex ).pack(side=tk.LEFT, fill=tk.X, expand=True) def getFolder(self): return self.folder.get() def setFolder(self, f): self.folder.set(f) def getEx(self): exs = self.ex.get().split(",") return [ex.strip() for ex in exs] def setEx(self, exs): if type(exs)==list: exs = ', '.join([ex.strip() for ex in exs]) self.ex.set(exs)
首先,folder和ex分別是左右兩個(gè)組件對(duì)應(yīng)的可變文本,為了便于更新和調(diào)用,類中設(shè)計(jì)了兩組、四對(duì)便攜方法getFolder, setFolder和getEx和setEx。由于Folder中的內(nèi)容就是文件夾本身,所以設(shè)置和讀取方法僅僅是StringVar的二次封裝,而ex中的內(nèi)容則不然,需要對(duì)文本進(jìn)行分割,并且實(shí)現(xiàn)字符串到列表的轉(zhuǎn)換。
完整組件
最后,是整個(gè)組件的布局,源碼如下
class FolderSplit(ttk.Frame): def __init__(self, master, **options): super().__init__(master, **options) self.pack() self.fs = FileSystem() self.initWidgets() def initWidgets(self): self.exForders = [] pDct = dict(side=tk.TOP, expand=True, fill=tk.X) self.srcFolder = DialogButton(self, 5, 25, 8, "文件夾", label="源路徑") self.srcFolder.pack(**pDct) self.dstFolder = DialogButton(self, 5, 25, 8, "文件夾", label="目標(biāo)路徑") self.dstFolder.pack(**pDct) btns = ttk.Frame(self) btns.pack(**pDct) ttk.Button(btns, text="? ", command=self.btnAddFolder).grid(row=0,column=0) ttk.Button(btns, text="?", command=self.btnDelFolder).grid(row=0,column=1) ttk.Button(btns, text="移動(dòng)", command=self.btnMove).grid(row=0,column=2) ttk.Button(btns, text="撤銷", command=self.btnReMove).grid(row=0,column=3) self.exFrm = ttk.LabelFrame(self, text="文件夾映射表") self.exFrm.pack(**pDct) for k, v in self.fs.fileDct.items(): self.addFolders(self.exFrm, k, v) def btnAddFolder(self): self.addFolders(self.exFrm, None, None) def addFolders(self, frm, folder, exs): ef = ExFolder(frm, folder, exs) ef.pack(side=tk.TOP, expand=True, fill=tk.X, padx=2, pady=1) self.exForders.append(ef) def btnDelFolder(self): if len(self.exForders) == 0: return self.exForders[-1].pack_forget() del self.exForders[-1] def setExDct(self): fileDct = {ef.getFolder() : ef.getEx() for ef in self.exForders} self.fs.update(fileDct) def btnMove(self): src = self.srcFolder.get() dst = self.dstFolder.get() self.setExDct() if dst=="": dst = src self.fs.start(src, dst) def btnReMove(self): self.fs.restore()
三個(gè)已經(jīng)實(shí)現(xiàn)的功能按鈕,?用于新增一個(gè)文件夾映射組件,?則移除最后一個(gè)映射組件。移除組件時(shí)需要注意,不僅僅要把組件解綁,還要把組件對(duì)應(yīng)的實(shí)例刪掉。
核心功能被綁定在移動(dòng)按鈕上,首先讀取源路徑和目標(biāo)路徑,如果目標(biāo)路徑未輸入,就在源路徑下工作。
接下來,將文件映射組件重新拆解為映射字典,最后調(diào)用FileSystem中的移動(dòng)方法,實(shí)現(xiàn)所有文件的移動(dòng)。
到此這篇關(guān)于Python基于面向?qū)ο笞鲆粋€(gè)文件夾整理工具的文章就介紹到這了,更多相關(guān)Python文件夾整理工具內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
用Python計(jì)算三角函數(shù)之a(chǎn)cos()方法的使用
這篇文章主要介紹了用Python計(jì)算三角函數(shù)之a(chǎn)cos()方法的使用,是Python學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-05-05python將字典內(nèi)容存入mysql實(shí)例代碼
這篇文章主要介紹了python將字典內(nèi)容存入mysql實(shí)例代碼,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01淺談Python peewee 使用經(jīng)驗(yàn)
這篇文章主要介紹了淺談Python peewee 使用經(jīng)驗(yàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10python next()和iter()函數(shù)原理解析
這篇文章主要介紹了python next()和iter()函數(shù)原理解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02Python連接SQL?server數(shù)據(jù)庫并進(jìn)行簡單查詢的操作詳解
SQL?Server是微軟推出的重量級(jí)的數(shù)據(jù)庫,本文將給大家詳細(xì)介紹了一下Python連接SQL?server數(shù)據(jù)庫詳細(xì)流程,并通過代碼示例給大家講解的非常清除,具有一定的參考價(jià)值,需要的朋友可以參考下2024-02-02Python實(shí)現(xiàn)網(wǎng)絡(luò)端口轉(zhuǎn)發(fā)和重定向的方法
這篇文章主要介紹了Python實(shí)現(xiàn)網(wǎng)絡(luò)端口轉(zhuǎn)發(fā)和重定向的方法,結(jié)合實(shí)例形式分析了Python基于threading和socket模塊實(shí)現(xiàn)端口轉(zhuǎn)發(fā)與重定向的具體操作技巧,需要的朋友可以參考下2016-09-09詳解利用Pandas求解兩個(gè)DataFrame的差集,交集,并集
這篇文章主要和大家講解一下如何利用Pandas函數(shù)求解兩個(gè)DataFrame的差集、交集、并集,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2022-07-07