python 解压、复制、删除 文件的实例代码

 更新时间:2020年02月26日 07:56:42   作者:缘来释你  
这篇文章主要介绍了python 解压、复制、删除 文件的实例代码,代码简单易懂非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

压缩复制删除文件基于python语言怎么操作呢,压缩文件有四种格式:zip、rar、tar、tar.gz,在压缩过程中也容易出现很多问题,今天小编通过代码给大家详解,具体内容如下所示:

一、python3解压文件

1.python 解压文件代码示例

如下代码主要实现zip、rar、tar、tar.gz四种格式的压缩文件的解压

def unzip_file(src_file, dst_dir=None, unzipped_files=None, del_flag=True):
 """
 根据指定的压缩文件类型递归解压所有指定类型的压缩文件
 :param src_file: 解压的源文件路径,可以为文件夹路径也可以是文件路径
 :param dst_dir: 解压后的文件存储路径
 :param unzipped_files: 完成解压的文件名列表
 :param del_flag: 解压完成后是否删除原压缩文件,默认删除
 :return: 完成解压的文件名列表
 """
 # 完成解压的文件名列表初始为空
 if unzipped_files is None:
  unzipped_files = []
 # 指定的解压文件类型
 zip_types = ['.zip', '.rar', '.tar', '.gz']

 def exec_decompress(zip_file, dst_dir):
  """
  解压实现的公共代码
  :param zip_file: 压缩文件全路径
  :param dst_dir: 解压后文件存储路径
  :return:
  """
  file_suffix = os.path.splitext(zip_file)[1].lower()
  try:
   print('Start extracting the file: %s' % zip_file)

   # zip 解压
   if file_suffix == '.zip':
    # zip解压 写法一
    with ZipFile(zip_file, mode='r') as zf:
     zf.extractall(dst_dir)
    # zip解压 写法二
    # file_zip = ZipFile(zip_file, mode='r')
    # for file in file_zip.namelist():
    #  file_zip.extract(file, dst_dir)
    # file_zip.close()

   # rar 解压
   elif file_suffix == '.rar':
    rf = rarfile.RarFile(zip_file)
    rf.extractall(dst_dir)

   # tar、tgz(tar.gz) 解压
   elif file_suffix in ['.tar', '.gz']:
    tf = tarfile.open(zip_file)
    tf.extractall(dst_dir)
    # 关闭文件释放内存
    tf.close()

   print('Finished extracting the file: %s' % zip_file)
  except Exception as e:
   print(e)
  # 解压完成加入完成列表
  unzipped_files.append(zip_file)
  # 根据标识执行原压缩文件删除
  if del_flag and os.path.exists(zip_file):
   os.remove(zip_file)

 # 如果传入的文件路径为文件目录,则遍历目录下所有文件
 if os.path.isdir(src_file):
  # 初始化文件目录下存在的压缩文件集合为空
  zip_files = []
  # 如果传入的目的文件路径为空,则取解压的原文件夹路径
  dst_dir = dst_dir if dst_dir else src_file
  # 遍历目录下所有文件
  for file in os.listdir(src_file):
   file_path = os.path.join(src_file, file)
   # 如果是文件夹则继续递归解压
   if os.path.isdir(file_path):
    dst_path = os.path.join(dst_dir, file)
    unzip_file(file_path, dst_path, unzipped_files)
   # 如果是指定类型的压缩文件则加入到压缩文件列表
   elif os.path.isfile(file_path) and os.path.splitext(file_path)[
    1].lower() in zip_types and file_path not in unzipped_files:
    zip_files.append(file_path)
  # 遍历压缩文件列表,执行压缩文件的解压
  for zip_file in zip_files:
   exec_decompress(zip_file, dst_dir)
  # 如果当前目录存在压缩文件则完成所有文件解压后继续遍历
  if zip_files:
   unzip_file(dst_dir, unzipped_files=unzipped_files)
 # 如果传入的文件路径是指定类型的压缩文件则直接执行解压
 elif os.path.isfile(src_file) and os.path.splitext(src_file)[1].lower() in zip_types:
  dst_dir = dst_dir if dst_dir else os.path.dirname(src_file)
  exec_decompress(src_file, dst_dir)

 return unzipped_files

2.python解压常见问题解决办法

2.1 python3 zipfile解压文件名乱码解决办法

直接修改源码,即 zipfile.py 文件:

第一处:

if flags & 0x800:
 # UTF-8 file names extension
 filename = filename.decode('utf-8')
else:
 # Historical ZIP filename encoding
 # 注释原代码
 # filename = filename.decode('cp437')
 # 新加一行代码
 filename = filename.decode('gbk')

 第二处:

if zinfo.flag_bits & 0x800:
 # UTF-8 filename
 fname_str = fname.decode("utf-8")
else:
 # 注释原代码
 # fname_str = fname.decode("cp437")
 # 同样新加一行代码
 fname_str = fname.decode('gbk')

2.1 rar 解压无法找到动态库(unrar.dll)解决办法

报错示例:

第一步 手动下载动态库文件 unrar.dll 存在本地目录,例如我的本地存储路径为:C:\MySoft\assist\unrar.dll

链接: https://pan.baidu.com/s/1rqhFND9XmtD1Y8yGLEz9kA 提取码: u2my

第二步 修改源码 unrarlib.py 文件

if platform.system() == 'Windows':
 from ctypes.wintypes import HANDLE as WIN_HANDLE
 HANDLE = WIN_HANDLE
 UNRARCALLBACK = ctypes.WINFUNCTYPE(ctypes.c_int, ctypes.c_uint,
          ctypes.c_long, ctypes.c_long,
          ctypes.c_long)
 # 注释原代码
 # lib_path = lib_path or find_library("unrar.dll")
 # 将路径指向下载的动态库文件存储路径
 lib_path = r"C:\MySoft\assist\unrar.dll"
 if lib_path:
  unrarlib = ctypes.WinDLL(lib_path)

知识点扩展:python 压缩文件夹的代码

def zip_ya(start_dir):
  start_dir = start_dir # 要压缩的文件夹路径
  file_news = start_dir + '.zip' # 压缩后文件夹的名字

  z = zipfile.ZipFile(file_news, 'w', zipfile.ZIP_DEFLATED)
  for dir_path, dir_names, file_names in os.walk(start_dir):
   f_path = dir_path.replace(start_dir, '') # 这一句很重要,不replace的话,就从根目录开始复制
   f_path = f_path and f_path + os.sep or '' # 实现当前文件夹以及包含的所有文件的压缩
   for filename in file_names:
    z.write(os.path.join(dir_path, filename), f_path + filename)
  z.close()
  return file_news

PS: 若递归扫描所有文件夹过程中有文件夹里不存在文件, 该文件夹将被忽略

总结

到此这篇关于python 解压、复制、删除 文件的实例代码的文章就介绍到这了,更多相关python 解压、复制、删除 文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Django中cookie的基本使用方法示例

    Django中cookie的基本使用方法示例

    这篇文章主要给大家介绍了关于Django中cookie的基本使用的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧。
    2018-02-02
  • 基于python list对象中嵌套元组使用sort时的排序方法

    基于python list对象中嵌套元组使用sort时的排序方法

    下面小编就为大家分享一篇基于python list对象中嵌套元组使用sort时的排序方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-04-04
  • 浅析matlab中imadjust函数

    浅析matlab中imadjust函数

    对进行图像的灰度变换,即调节灰度图像的亮度或彩色图像的颜色矩阵。这篇文章主要介绍了matlab中imadjust函数,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友参考下
    2020-02-02
  • np.newaxis()函数的具体使用

    np.newaxis()函数的具体使用

    本文主要介绍了np.newaxis()函数的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • python使用PyV8执行javascript代码示例分享

    python使用PyV8执行javascript代码示例分享

    这篇文章主要介绍了python使用PyV8执行javascript的小示例,大家参考使用吧
    2013-12-12
  • Python基础之字典的详细使用教程

    Python基础之字典的详细使用教程

    字典作为Python的一个内置数据结构,和列表一样都是可变序列的,但是它是无序的,以键值对的方式存储数据。本文将详解一下Python中字典的使用,需要的可以参考一下
    2022-07-07
  • 使用IPython或Spyder将省略号表示的内容完整输出

    使用IPython或Spyder将省略号表示的内容完整输出

    这篇文章主要介绍了使用IPython或Spyder将省略号表示的内容完整输出,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-04-04
  • python pptx复制指定页的ppt教程

    python pptx复制指定页的ppt教程

    今天小编就为大家分享一篇python pptx复制指定页的ppt教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-02-02
  • python入门基础之用户输入与模块初认识

    python入门基础之用户输入与模块初认识

    Python的强大之处在于他有非常丰富和强大的标准库和第三方库,几乎你想实现的任何功能都有相应的Python库支持。下面通过本文给大家介绍python入门基础之用户输入与模块初认识,一起看看吧
    2016-11-11
  • python爬虫 基于requests模块的get请求实现详解

    python爬虫 基于requests模块的get请求实现详解

    这篇文章主要介绍了python爬虫 基于requests模块的get请求实现详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08

最新评论