经常存在在我们的电脑中的垃圾文件主要是指系统在运行过程中产生的tmp临时文件、日志文件、临时备份文件等。垃圾清理器的作用其实也是对这些文件进行清理,不会影响到我们使用产生的数据文件。如果是手动删除的话要一个一个的找出来去删除就比较麻烦了,用python写一个脚本直接启动就大功告成了。
在这个脚本的实现过程中使用到的内置库就是os库,没有通过其他的三方插件进行实现。所以也不用下载其他的python模块,直接调用内置库就OK了。
import os
因为我们使用界面化的处理,这里导入一下pyqt5的模块来实现UI界面布局。
from PyQt5.QtGui import *
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
import sys
先将需要使用的UI界面编写完成,还是使用前面涉及到的界面开发的编写方式。
class FileDestory(QWidget):
def __init__(self):
super(FileDestory, self).__init__()
self.init_ui()
def init_ui(self):
self.setWindowTitle('电脑垃圾清理器 公众号:[Python 集中营]')
self.setWindowIcon(QIcon('垃圾桶.ico'))
self.setFixedWidth(550)
self.setFixedHeight(80)
self.process = QProgressBar()
self.process.setRange(0, 5)
self.start_btn = QPushButton()
self.start_btn.setText('开始清理')
self.start_btn.clicked.connect(self.start_btn_click)
hbox = QHBoxLayout()
hbox.addWidget(self.process)
hbox.addWidget(self.start_btn)
self.thread_ = WorkThread(self)
self.thread_.finished.connect(self.finished)
self.thread_.exec_step.connect(self.set_step)
self.setLayout(hbox)
def start_btn_click(self):
self.start_btn.setEnabled(False)
self.thread_.start()
def finished(self, finished):
if finished is True:
self.start_btn.setText('清理已完成')
self.start_btn.setEnabled(False)
def set_step(self, step):
self.process.setValue(step)
创建工作子线程,所有关于电脑清理的操作都放在这个子线程中去执行,和主线程分离开来避免主线程直接卡死,因为主线程主要是用来处理UI界面相关的操作。
class WorkThread(QThread):
# 定义好信号量用来向主线程中传递变量的变化信息,这样主线程就可以知道运行结果如何。
# 子线程是否执行完成的信号变量
finished = pyqtSignal(bool)
# 子线程具体的步骤信号变量
exec_step = pyqtSignal(int)
def __init__(self, parent=None):
'''
子线程类的初始化函数
:param parent: UI界面类对象
'''
super(WorkThread, self).__init__(parent)
self.working = True
self.parent = parent
def __del__(self):
'''
线程执行是否需要进入等待过程
:return:
'''
self.working = False
self.wait()
def run(self):
'''
子线程主要执行逻辑的业务函数
:return:
'''
file_type = {
'.tmp': '临时文件',
'._mp': '临时文件_mp',
'.log': '日志文件',
'.gid': '临时帮助文件',
'.chk': '磁盘检查文件',
'.old': '临时备份文件',
'.xlk': 'Excel备份文件',
'.bak': '临时备份文件bak'
}
user_pro = os.environ['userprofile']
def del_file_and_dir(root):
try:
if os.path.isfile(root):
os.remove(root)
print("文件", root, "已经被移除!")
elif os.path.isdir(root):
os.rmdir(root)
print("文件夹", root, "已经被移除!")
except WindowsError:
print("该文件", root, "不能被移除!")
def init_size(b):
try:
kb = b // 1024
except:
print("传入字节格式不对")
return "Error"
if kb > 1024:
M = kb // 1024
if M > 1024:
G = M // 1024
return "%dG" % G
else:
return "%dM" % M
else:
return "%dkb" % kb
class Clean(object):
def __init__(self):
self.del_info = {}
self.del_file_paths = []
self.total_size = 0
for i, j in file_type.items():
self.del_info[i] = dict(name=j, count=0)
def count_files(self):
for roots, dirs, files in os.walk(user_pro):
for files_item in files:
file_extension = os.path.splitext(files_item)[1]
if file_extension in self.del_info:
file_full_path = os.path.join(roots, files_item)
self.del_file_paths.append(file_full_path)
self.del_info[file_extension]['count'] += 1
self.total_size += os.path.getsize(file_full_path)
def show_del_files(self):
re = init_size(self.total_size)
for i in self.del_info:
print(self.del_info[i]["name"], "共计", self.del_info[i]["count"], "个")
return re
def delete_files(self):
for path in self.del_file_paths:
print('准备处理文件路径:', path)
del_file_and_dir(path)
self.exec_step.emit(1)
clean = Clean()
self.exec_step.emit(2)
clean.count_files()
self.exec_step.emit(3)
re = clean.show_del_files()
self.exec_step.emit(4)
clean.delete_files()
self.exec_step.emit(5)
self.finished.emit(True)
将布局加入main函数主体循环中,启动整个应用。
if __name__ == '__main__':
app = QApplication(sys.argv)
main = FileDestory()
main.show()
sys.exit(app.exec_())
以上就是自动清理电脑垃圾文件的全部代码块了,copy 到开发工具中直接运行即可。
【往期精选】
有了jmespath,处理python中的json数据就变成了一种享受...
解锁一个新技能,如何在Python代码中使用表情包...
万能的list列表,python中的堆栈、队列实现全靠它!
该怎么用pyqt5来实现数据的增、删、改、查功能...
介绍一个文本语音神器,几行代码就能搞定!
python批量自动整理文件
初学者福利:分享五个免费的 Python 学习网站,抓紧收藏吧!
有趣的控制台玩法:一行代码绘制控制台图像!
数据处理小工具:Excel 批量数据文件拆分/整合器...
办公自动化:PDF文件合并器,将多个PDF文件进行合并...
GUI猜数字游戏,直接开玩...
手把手教你做一个数据图表生成器(附源码)...
网友评论