Python中shutil模块的使用详解

 更新时间:2022年01月24日 11:54:36   作者:三爷带你飞  
这篇文章主要为大家介绍了Python中shutil模块的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

简介:shutil 模块提供了一系列对文件和文件集合的高阶操作。特别是提供了一些支持文件拷贝和删除的函数,该模块主要强大之处在于其对文件的复制与删除操作更是比较支持好。

主要方法:

1、复制文件

2、复制文件夹

3、文件、文件夹移动

4、文件、文件夹改名

5、永久删除文件和文件夹

6、文件、文件夹进行打包

复制文件、并进行文件改名:

import shutil
# 复制文件、并进行文件改名 copy
src_copy = r"D:\codes\ai2022\test1\a1.txt"
dst_copy = r"D:\codes\ai2022\test2\a2.txt"
shutil.copy(src_copy, dst_copy)

复制文件夹:

# 复制文件夹 copytree
src_copytree = r"D:\codes\ai2022\test1"
dst_copytree = r"D:\codes\ai2022\test3"
shutil.copytree(src_copytree, dst_copytree)

文件移动:如果目标目录存在同名文件,则报错:already exists

# 文件移动 move
src_move = r"D:\codes\ai2022\test2"
dst_move = r"D:\codes\ai2022\test3"
shutil.move(src_move, dst_move)

文件夹移动:

# 文件夹移动 move
src_move_dir = r"D:\codes\ai2022\test2"
dst_move_dir= r"D:\codes\ai2022\test3"
shutil.move(src_move_dir, dst_move_dir)

图片

永久删除文件和文件夹:

利用 os 模块中的函数,可以删除一个文件或一个空文件夹。但利用 shutil 模块,可以删除一个文件夹及其所有的内容。

# 删除文件夹包含的所有文件和文件夹都会被删除。
dst_remove_dir= r"D:\codes\ai2022\test3"
shutil.rmtree(dst_remove_dir)

文件、文件夹进行打包:

# 文件、文件夹打包:shutil.make_archive
# 最终压缩包的文件路径地址、压缩包文件名。只传文件名则默认当前路径
zip_path = r"D:\codes\ai2022\test5\test_zip"
# 需要进行压缩的文件路径
root_dir = r"D:\codes\ai2022\test4"
# 压缩包的类型可以是"zip", "tar", "gztar", "bztar", or "xztar"
result = shutil.make_archive(zip_path, 'zip', root_dir=root_dir)
print(f"root_dir:{root_dir}")

创建打包参数详解:

base_name:压缩包的文件名,也可以是压缩包的路径。只是文件名时,则保存至当前目录,否则保存至指定路径,
format:压缩包种类,“zip”, “tar”, “bztar”,“gztar”
root_dir:要压缩的文件夹路径(默认当前目录)
owner:用户,默认当前用户
group:组,默认当前组
logger:用于记录日志,通常是logging.Logger对象

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

相关文章

  • 一篇文章带你了解kali局域网攻击

    一篇文章带你了解kali局域网攻击

    这篇文章主要给大家介绍了kali的局域网攻击,小编觉得这篇文章还是不错的,使用起来也是非常方便的,需要的朋友可以参考下
    2021-08-08
  • Python3中使用urllib的方法详解(header,代理,超时,认证,异常处理)

    Python3中使用urllib的方法详解(header,代理,超时,认证,异常处理)

    这篇文章整理了一些关于urllib使用中的一些关于header,代理,超时,认证,异常处理处理方法,对大家学习python具有一定的参考借鉴价值,有需要的朋友们下面来一起看看吧。
    2016-09-09
  • Python连接PostgreSQL数据库的方法

    Python连接PostgreSQL数据库的方法

    大家应该都有所了解,python可以操作多种数据库,诸如SQLite、MySql、PostgreSQL等,这里不对所有的数据库操作方法进行赘述,只针对目前项目中用到的PostgreSQL做一下简单介绍,主要是Python连接PostgreSQL数据库的方法。有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-11-11
  • Boston数据集预测放假及应用优缺点评估

    Boston数据集预测放假及应用优缺点评估

    这篇文章主要为大家介绍了Boston数据集预测放假及应用优缺点评估,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • Python操作SQLite数据库的方法详解

    Python操作SQLite数据库的方法详解

    这篇文章主要介绍了Python操作SQLite数据库的方法,较为详细的分析了Python安装sqlite数据库模块及针对sqlite数据库的常用操作技巧,需要的朋友可以参考下
    2017-06-06
  • Python实现生成指定大小文件的示例详解

    Python实现生成指定大小文件的示例详解

    这篇文章主要为大家详细介绍了Python如何实现生成指定大小文件,例如txt/图片/视频/csv等,文中的示例代码讲解详细,需要的可以参考下
    2023-08-08
  • 一小时学会TensorFlow2之基本操作2实例代码

    一小时学会TensorFlow2之基本操作2实例代码

    这篇文章主要介绍了TensorFlow2的基本操作和实例代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-09-09
  • python算法与数据结构朋友圈与水杯实验题分析实例

    python算法与数据结构朋友圈与水杯实验题分析实例

    这篇文章主要介绍了python算法与数据结构朋友圈与水杯实验题分析,总的来说这并不是难题,那为什么要拿出这道题介绍?拿出这道题真正想要传达的是解题的思路,以及不断优化探寻最优解的过程。希望通过这道题能给你带来一种解题优化的思路
    2022-12-12
  • Django使用paginator插件实现翻页功能的实例

    Django使用paginator插件实现翻页功能的实例

    今天小编就为大家分享一篇关于Django使用paginator插件实现翻页功能的实例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-10-10
  • 200行python代码实现2048游戏

    200行python代码实现2048游戏

    这篇文章主要为大家详细介绍了200行Python代码实现2048游戏,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-07-07

最新评论