前言
大家应该都有所体会,在windows系统使用久了就会产生一些“垃圾”文件。这些文件有的是程序的临时文件,有的是操作记录或日志等。垃圾随着时间越积越多,导致可用空间减少,文件碎片过多,使得系统的运行速度受到一定影响。
而Mac系统和Linux系统并不存在这类问题,所以只适用于windows
知识概要
某些缓存文件可以提高程序的执行速度,比如缓存 cookie、使用记录 recent、预读取 prefetch 等。所以清理临时文件并不代表系统运行就会变快,有时也可能变慢。
windows电脑中的垃圾文件及文件夹主要有哪些?
系统盘 %system% 下文件类型:
【临时文件(*.tmp)】
【临时文件(*._mp)】
【日志文件(*.log)】
【临时帮助文件(*.gid)】
【磁盘检查文件(*.chk)】
【临时备份文件(*.old)】
【Excel备份文件(*.xlk)】
【临时备份文件(*.bak)】
用户目录 %userprofile% 下文件夹
【COOKIE】 cookies\*.*
【文件使用记录】 recent\*.*
【IE临时文件】 Temporary Internet Files\*.*
【临时文件文件夹】 Temp\*.*
Windows 目录 %windir% 下文件夹
【预读取数据文件夹】 prefetch\*.*
【临时文件】 temp\*.*
获取文件地址
操作需要os模块,如获取工作目录:
import os print os.getcwd() # 'E:\\PythonSource\\leanr_py'
切换工作目录:
os.chdir('d://wamp') print os.getcwd() # 'd:\\wamp'
获取系统盘符:
os.environ['systemdrive'] # 'C:'
获取用户目录:
os.environ['userprofile'] # 'C:\\Users\\Administrator'
获取 Windows 目录:
os.environ['windir'] # 'C:\\Windows'
遍历目录
要想遍历文件夹,需要用到 os.walk(top,topdown=True,onerror=None)
for roots, dirs, files in os.walk('d://wamp', topdown=False) # roots 文件夹路径, dirs 该目录下的文件夹列表, files文件列表 print roots # d://wamp print dirs # ['bin', 'www', 'alias'] print files # ['wampmanage.conf', '1.txt']
判断是否垃圾文件
os.path.splitext() 可以对文件名进行切割
extension = os.path.splitext(r'aaa\bbb\ccc.ddd') # ('aaa\\bbb\\ccc', '.ddd') if extension[1] in ['.tmp', '.bak']: print '是垃圾文件'
删除文件
删除文件与删除文件夹调用的是不同的函数。
# 删除文件 os.remove('d:temporary/test/test.txt') # 删除文件夹 os.rmdir('d:temporary/test/empty')
os.rmdir 只能删除空文件夹,如果文件夹非空,则会报错。所以应该用:
shutil.rmtree('d:/dir1/dir2/aaa')
文件正在运行或者受到保护、当前账户没有足够权限时,删除会报错。
最后整理删除函数为:
def del_dir_or_file(root): try: if os.path.isfile(root): # 删除文件 os.remove(root) print 'file: ' + root + ' removed' elif os.path.isdir(root): # 删除文件夹 shutil.rmtree(root) print 'directory: ' + root + ' removed' except WindowsError: print 'failure: ' + root + " can't remove"
获取文件大小
# 显示文件夹(路径)大小,单位 bite os.path.getsize('d://temporary/test') # 4096 # 文件大小 os.path.getsize('d://temporary/test/aaa.txt') # 135
完整程序
注意:由于牵涉到文件删除操作,请在动手前务必反复确认代码,万一导致什么重要文件被删.
务必确认!!!
务必确认!!!
务必确认!!!
import os import json import shutil del_extension = { '.tmp': '临时文件', '._mp': '临时文件_mp', '.log': '日志文件', '.gid': '临时帮助文件', '.chk': '磁盘检查文件', '.old': '临时备份文件', '.xlk': 'Excel备份文件', '.bak': '临时备份文件bak' } del_userprofile = ['cookies', 'recent', 'Temporary Internet Files', 'Temp'] del_windir = ['prefetch', 'temp'] # 获取系统盘 SYS_DRIVE = os.environ['systemdrive'] + '\\' # 获取用户目录 USER_PROFILE = os.environ['userprofile'] # 获取 Windows 目录 WIN_DIR = os.environ['windir'] # 获取当前路径 os.getcwd() 'E:\\Software\\Python27' # 跳转至指定的文件目录 os.chdir('d://wamp') # 获取系统盘符 os.environ['systemdrive'] 'C:' # 获取用户目录 os.environ['userprofile'] 'C:\\Users\\Administrator' # 获取 Windows 目录 os.environ['windir'] 'C:\\Windows' def del_dir_or_file(root): try: if os.path.isfile(root): # 删除文件 os.remove(root) print 'file: ' + root + ' removed' elif os.path.isdir(root): # 删除文件夹 shutil.rmtree(root) print 'directory: ' + root + ' removed' except WindowsError: print 'failure: ' + root + " can't remove" # 字节bytes转化kb\m\g def formatSize(bytes): try: bytes = float(bytes) kb = bytes / 1024 except: print("传入的字节格式不对") return "Error" if kb >= 1024: M = kb / 1024 if M >= 1024: G = M / 1024 return "%fG" % (G) else: return "%fM" % (M) else: return "%fkb" % (kb) class DiskClean(object): def __init__(self): self.del_info = {} self.del_file_paths = [] self.total_size = 0 for k,v in del_extension.items(): self.del_info[k] = dict(name = v, count = 0) def scan(self): for roots, dirs, files in os.walk(USER_PROFILE, topdown=False): # 生成并展开以 root 为根目录的目录树,参数 topdown 设定展开方式从底层到顶层 for file_item in files: # 获取扩展名 file_extension = os.path.splitext(file_item)[1] # print os.path.join(roots, file_item) if file_extension in self.del_info: # 文件完整路径 file_full_path = os.path.join(roots, file_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(self): print json.dumps(self.del_info, indent=4, ensure_ascii=False) print '删除可节省:%s 空间' % formatSize(self.total_size) def delete_files(self): for i in self.del_file_paths: del_dir_or_file(i) if __name__ == '__main__': cleaner = DiskClean() cleaner.scan() cleaner.show() if_del = raw_input('是否删除y/n:') if if_del == 'y': cleaner.delete_files()
总结
最近在看一些qt界面的内容。可以结合做一个有图形界面的程序 。以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
对于以前的光盘一般都是用批处理来达到安装完相应的软件而清理掉的效果! 但可以看出用 NSIS 同样也可以实现。 当然也可以参考集成光盘安装时产生的垃圾简易清理器(批处理) http://dreams8.com/viewthread.php?tid=789 其实批处理都能实现的,但用NSIS打包一下是不是更酷呢? 引用脚本的内容: ; 该脚本使用 HM VNISEdit 脚本编辑器向导产生 ;
引用CLEAN.nsi的内容: ; 该脚本使用 HM VNISEdit 脚本编辑器向导产生 ; 安装程序初始定义常量 !define PRODUCT_NAME "Windows简易垃圾清理器" !define PRODUCT_VERSION "1.0" !define PRODUCT_PUBLISHER "似水年华" SetCompressor /final /SOLID lzma ; --
问题内容: Nova在世界上是如何管理的?我实际上是在尝试做完全相同的事情:为用户提供一个按钮,以按清除并选择他们的新默认启动器。 我可以获取默认应用名称并显示它: 这里是 然后我调用系统ResolveActivity, 选择器启动并正常运行,但实际上并未设置或清除任何值。在调试它时,好像我缺少一些额外功能吗?当我调用该方法时,会收到以下日志消息, 当我使用Nova实施时,我看到了所有这些, 我如
嗨, 我偶然发现了的一个问题,在这个问题上,进程应该不能访问数据。让我解释一下: 我有一个类似于下面示例的情况:我得到了几个运行,每个运行以不同的参数开始。他们并行计算他们的东西,没有理由相互交互。现在,正如我所理解的,当一个进程分叉时,它会复制自己。子进程与其父进程具有相同的(内存)数据,但是如果它更改任何内容,它将在自己的副本上进行更改。如果我想让更改在子进程的生命周期内继续存在,我会调用队列
本文向大家介绍如何清理docker产生的垃圾文件,包括了如何清理docker产生的垃圾文件的使用技巧和注意事项,需要的朋友参考一下 无意中感觉磁盘空间不够用,于是使用df -a命令查看,结果令人大吃一惊,全是docker干的好事,在/var/lib/docker/aufs里生成了一堆垃圾: 首先使用最简单的方法,清理当前未运行的所有Docker容器: 运行结果如下: 如果空间释放得还够多,就想办法