Python在后台自动解压各种压缩文件的实现方法


Posted in Python onNovember 10, 2020

1.需求描述

编写一个 Python 程序,每次下载压缩包形式的文件后,自动将内部文件解压到当前文件夹后将压缩包删除,通过本案例可以学到的知识点:

  • os 模块综合应用
  • glob 模块综合应用
  • 利用 gzip zipfile rarfile tarfile 模块解压文件

2.步骤分析和前置知识

码代码之前需要将复杂问题解释成多个明确的要求,即这个程序实现的逻辑为:

  1. 定时检测某个文件夹(如 download 文件夹)是否存在压缩文件
  2. 如果有新出现的压缩文件则将其解压到当前文件夹内的新文件夹中 删除压缩文件
  3. 提到压缩文件就要分不同压缩格式进行讨论,主要有以下4种:

提到压缩文件就要分不同压缩格式进行讨论,主要有以下4种:

.gz: 即 gzip,通常只能压缩一个文件
.tar: 本质上不是压缩工具而是打包工具,可以跟 .gz 配合形成 .tar.gz 的打包压缩格式 .zip: 和 .tar.gz 很类似但可以打包压缩多个文件
.rar: 打包压缩文件,最初用于 DOS

因此,文件是否为压缩文件的判断逻辑可以如下:

  1. 建立一个含压缩包后缀的列表 compressed_lst = ['gz', 'tar', 'zip', 'rar']
  2. 目标文件夹下的所有文件名运行 filename.split(.)[-1] 获取后缀名
  3. 判断后缀名是否在 compressed_lst 中,如果存在则运行后续的解压代码
  4. 如果是以 gz 结尾的文件,解压后需要再次判断是否是以 .tar 结尾,并进行相应处理

不同压缩文件的解压代码各不相同,在后续代码操作中具体展开。

3.代码实现

首先是获取 download 文件夹下所有文件的文件名

import glob
import os

path = r'C:\xxxx\download'
file_lst = glob.glob(path + '/*')
# 列表推导式
filename_lst = [os.path.basename(i) for i in file_lst]

print(filename_lst)

接下来根据文件的后缀名判断是否需要压缩,先看一下代码框架

for i in filename_lst:
 if '.' in i:
  # 获取后缀名
  suffix = i.split('.')[-1]
  # 逐个将后缀名和各格式的压缩后缀匹配
  if suffix == 'gz':
   pass
   if ...: # 再次判断新产生的文件名是否以 .tar 结尾
    pass
  if suffix == 'tar':
   pass
  if suffix == 'zip':
   pass
  if suffix == 'rar':
   pass

这里有2个注意点:

有些文件没有后缀名,因此可能不存在 .,这时用 filename.split('.')[-1]会报错,因此需要先判断
以.gz 结尾的文件,解压后需要再次判断是否是以 .tar 结尾,然后我们就可以分别将四种压缩文件的解压代码写成函数,符合时候单独调用即可
1、处理.gz 文件

import gzip

def ungz(filename):
 filename = filename[:-3] # gz文件的单文件解压就是去掉 filename 后面的 .gz
 gz_file = gzip.GzipFile(filename)
 with open(filename, "w+") as file:
  file.write(gz_file.read())
  return filename # 这个gzip的函数需要返回值以进一步配合untar函数

前面反复提及的 gz 文件有可能跟 tar 文件配合,因此解压 gz 文件后需要再判断是否有必要解开 tar 文件
这里就可以先把 tar 文件的函数写出来
2、处理.tar文件

import tarfile

def untar(filename):
 tar = tarfile.open(filename)
 names = tar.getnames()
 # tar本身是将文件打包,解除打包会产生很多文件,因此需要建立文件夹存放
 if not os.path.isdir(filename + "_dir"):
  os.mkdir(filename + "_dir")
 for name in names:
  tar.extract(name, filename + "_dir/")
 tar.close()

3、处理.zip文件

import zipfile

def unzip(filename):
 zip_file = zipfile.ZipFile(filename)
 # 类似tar解除打包,建立文件夹存放解压的多个文件
 if not os.path.isdir(filename + "_dir"):
  os.mkdir(filename + "_dir")
 for names in zip_file.namelist():
  zip_file.extract(names, filename + "_dir/")
 zip_file.close()

4、处理.rar文件

import rarfile

def unrar(filename):
 rar = rarfile.RarFile(filename)
 if not os.path.isdir(filename + "_dir"):
  os.mkdir(filename + "_dir")
 os.chdir(filename + "_dir")
 rar.extractall()
 rar.close()

可以看到,四种解压代码略有不同,推荐大家实际演示中自己体会一下差别,解压后配合 os.remove() 就可以删除压缩包,现在看看逻辑框架补上解压函数后的内容:

for filename in filename_lst:
 if '.' in filename:
  suffix = filename.split('.')[-1]
  if suffix == 'gz':
   new_filename = ungz(filename)
   os.remove(filename)
   if new_filename.split('.')[-1] == 'tar':
    untar(new_filename)
    os.remove(new_filename) 
  if suffix == 'tar':
   untar(filename)
   os.remove(filename)
  if suffix == 'zip':
   unzip(filename)
   os.remove(filename)
  if suffix == 'rar':
   unrar(filename)
   os.remove(filename)

5、实现实时检测

比较简单的方法就是建立 while True 死循环配合 time.sleep()睡眠,框架如下:

import time

while True:
 func()
 time.sleep(5) # 睡眠秒数可以设置大一点避免过度占用资源

最后将第二步的实现代码改为函数并放在循环框架中就可以完成本次需求,完整代码如下

import glob
import os
import gzip
import tarfile
import zipfile
import rarfile
import time

path = r'C:\xxxx\download'
file_lst = glob.glob(path + '/*')
filename_lst = [os.path.basename(i) for i in file_lst]

def ungz(filename):
 filename = filename[:-3]
 gz_file = gzip.GzipFile(filename)
 with open(filename, "w+") as file:
  file.write(gz_file.read())
 return filename

def untar(filename):
 tar = tarfile.open(filename)
 names = tar.getnames()
 if not os.path.isdir(filename + "_dir"):
  os.mkdir(filename + "_dir")
 for name in names:
  tar.extract(name, filename + "_dir/")
 tar.close()

def unzip(filename):
 zip_file = zipfile.ZipFile(filename)
 if not os.path.isdir(filename + "_dir"):
  os.mkdir(filename + "_dir")
 for names in zip_file.namelist():
  zip_file.extract(names, filename + "_dir/")
 zip_file.close()

def unrar(filename):
 rar = rarfile.RarFile(filename)
 if not os.path.isdir(filename + "_dir"):
  os.mkdir(filename + "_dir")
 os.chdir(filename + "_dir")
 rar.extractall()
 rar.close()

def unzip_files():
 for filename in filename_lst:
  if '.' in filename:
   suffix = filename.split('.')[-1]
   if suffix == 'gz':
    new_filename = ungz(filename)
    os.remove(filename)
    if new_filename.split('.')[-1] == 'tar':
     untar(new_filename)
     os.remove(new_filename)
   if suffix == 'tar':
    untar(filename)
    os.remove(filename)
   if suffix == 'zip':
    unzip(filename)
    os.remove(filename)
   if suffix == 'rar':
    unrar(filename)
    os.remove(filename)

while True:
 unzip_files()
 time.sleep(5)

到此这篇关于Python在后台自动解压各种压缩文件的实现方法的文章就介绍到这了,更多相关Python自动解压各种压缩文件内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python算法输出1-9数组形成的结果为100的所有运算式
Nov 03 Python
详解如何使用Python编写vim插件
Nov 28 Python
pygame游戏之旅 按钮上添加文字的方法
Nov 21 Python
Python实现将多个空格换为一个空格.md的方法
Dec 20 Python
python 自动批量打开网页的示例
Feb 21 Python
Python3实现的简单工资管理系统示例
Mar 12 Python
Python为何不能用可变对象作为默认参数的值
Jul 01 Python
python可视化实现KNN算法
Oct 16 Python
Python+Selenium+phantomjs实现网页模拟登录和截图功能(windows环境)
Dec 11 Python
tensorflow 实现从checkpoint中获取graph信息
Feb 10 Python
python 基于PYMYSQL使用MYSQL数据库
Dec 24 Python
python实现学生信息管理系统(面向对象)
Jun 05 Python
Python高阶函数与装饰器函数的深入讲解
Nov 10 #Python
pytorch学习教程之自定义数据集
Nov 10 #Python
pytorch加载语音类自定义数据集的方法教程
Nov 10 #Python
sublime3之内网安装python插件Anaconda的流程
Nov 10 #Python
python+excel接口自动化获取token并作为请求参数进行传参操作
Nov 10 #Python
python request 模块详细介绍
Nov 10 #Python
解决使用Pandas 读取超过65536行的Excel文件问题
Nov 10 #Python
You might like
PHP file_get_contents 函数超时的几种解决方法
2009/07/30 PHP
判断Keep-Alive模式的HTTP请求的结束的实现代码
2011/08/06 PHP
分享50个提高PHP执行效率的技巧
2015/12/26 PHP
PHP水印类,支持添加图片、文字、填充颜色区域的实现
2017/02/04 PHP
php 利用socket发送GET,POST请求的实例代码
2020/07/04 PHP
获取div编辑框,textarea,input text的光标位置 兼容IE,FF和Chrome的方法介绍
2012/11/08 Javascript
js原生appendChild的bug解决心得分享
2013/07/01 Javascript
不提示直接关闭网页窗口的JS示例代码
2013/12/17 Javascript
jQuery带进度条全屏图片轮播特效代码分享
2020/06/28 Javascript
jQuery实现的鼠标滑过弹出放大图片特效
2016/01/08 Javascript
AngularJS Ajax详解及示例代码
2016/08/17 Javascript
通过网页查看JS源码中汉字显示乱码的解决方法
2016/10/26 Javascript
如何制作幻灯片(代码分享)
2017/01/06 Javascript
React Js 微信禁止复制链接分享禁止隐藏右上角菜单功能
2017/05/26 Javascript
JS中Safari浏览器中的Date
2017/07/17 Javascript
vue中slot(插槽)的介绍与使用
2018/11/12 Javascript
js实现简单五子棋游戏
2020/05/28 Javascript
vue接口请求加密实例
2020/08/11 Javascript
[06:49]2018DOTA2国际邀请赛寻真——VirtusPro傲视群雄
2018/08/12 DOTA
跟老齐学Python之编写类之三子类
2014/10/11 Python
Python爬虫抓取手机APP的传输数据
2016/01/22 Python
Python利用Beautiful Soup模块创建对象详解
2017/03/27 Python
python3将视频流保存为本地视频文件
2018/06/20 Python
解决pycharm的Python console不能调试当前程序的问题
2019/01/20 Python
浅谈python3中input输入的使用
2019/08/02 Python
python+tkinter实现学生管理系统
2019/08/20 Python
python中sort和sorted排序的实例方法
2019/08/26 Python
python 如何对logging日志封装
2020/12/02 Python
HTML5新表单元素_动力节点Java学院整理
2017/07/12 HTML / CSS
说一下Linux下有关用户和组管理的命令
2016/01/04 面试题
会计系毕业个人自荐信格式
2013/09/23 职场文书
教师见习报告范文
2014/11/03 职场文书
致地震灾区的慰问信
2015/03/23 职场文书
2015年庆祝国庆节66周年演讲稿
2015/07/30 职场文书
《司马光》教学反思
2016/02/22 职场文书
小学作文指导之如何写人?
2019/07/08 职场文书