用Python复制文件的九种方法

以下是演示“如何在Python中复制文件”九种方法

  1. shutil copyfile()方法
  2. shutil copy()方法
  3. shutil copyfileobj()方法
  4. shutil copy2()方法
  5. os popen方法
  6. os系统()方法
  7. Thread()方法
  8. 子进程调用()方法
  9. 子进程check_output()方法

1. Shutil Copyfile()方法

该方法只有在目标可写时才将源的内容复制到目的地。如果您没有写入权限,则会引发IOError

它通过打开输入文件进行阅读,忽略其文件类型。接下来,它不会对特殊文件进行任何不同的处理,也不会将它们复制为新的特殊文件。

所述的CopyFile()方法利用较低级别的功能的copyfileobj()的下方。它将文件名称作为参数,打开它们并将文件句柄传递给copyfileobj()。该方法中有一个可选的第三个参数,您可以使用它来指定缓冲区长度。然后它将打开文件以读取指定缓冲区大小的块。但是,默认行为是一次性读取整个文件。

以下是有关copyfile()方法的要点。

  • 它将源的内容复制到名为目标的文件。
  • 如果目的地不可写,则复制操作将导致IOError异常。
  • 如果源文件和目标文件都相同,它将返回SameFileError
  • 但是,如果目的地以不同的名称预先存在,则副本将覆盖其内容。
  • 如果目的地是目录,则意味着此方法将不会复制到目录,将会发生错误13。
  • 它不支持复制文件,如字符或块设备和管道。

2. Shutil Copy()方法

copy()方法的功能类似于“CP”在Unix命令。这意味着如果目标是一个文件夹,那么它将在其中创建一个与源文件相同的名称(basename)的新文件。此外,该方法将复制其内容后将目标文件的权限与源进行同步。 如果要复制相同的文件,它也会抛出SameFileError

3. Shutil Copyfileobj()方法

此方法将文件复制到目标路径或文件对象。如果目标是文件对象,则需要在调用copyfileobj()之后明确关闭它。它假设一个可选参数(缓冲区大小),您可以使用它来提供缓冲区长度。这是在复制过程中保存在内存中的字节数。系统使用的默认大小为16KB。

4. Shutil Copy2()方法

但是,copy2()方法的功能类似于copy()。但是,在复制数据的同时,也可以在元数据中添加访问和修改时间。复制同一个文件会导致SameFileError

对于好奇 – Copymode()与Copystat()之间的区别。

5. Os Popen()方法

该方法创建一个指向或来自该命令的管道。它返回一个连接到管道的打开的文件对象。您可以根据文件打开模式(即’r’(默认)或’w’)使用它进行读取或写入。

  • 模式 –它可以是’r’(默认)或’w’。
  • bufsize –如果其值为0,则不会发生缓冲。如果设置为1,则在访问文件时将进行行缓冲。如果您提供的值大于1,则缓冲将以指定的缓冲区大小进行。但是,对于负值,系统将采用默认缓冲区大小。

对于Windows操作系统。

对于Linux操作系统。

6. Os System()方法

它是运行任何系统命令的最常见方式。使用system()方法,可以在subshell中调用任何命令。在内部,这种方法会调用标准的C库函数。

此方法返回命令的退出状态。

对于Windows操作系统。

对于Linux操作系统。

7.以Async方式使用线程库的Python文件复制

如果要以异步方式复制文件,请使用以下方法。在这里,我们使用Python的线程模块在后台运行复制操作。

使用此方法时,请确保采用锁定以避免死锁。如果您的应用程序正在使用多个线程读取/写入文件,您可能会面对它。

8.使用子进程的Call()方法在Python中复制一个文件

子进程模块提供了一个简单的界面来处理子进程。它使我们能够启动子进程,附加到其输入/输出/错误管道,并检索返回值。

子流程模块旨在替代传统模块和功能,如*os.system,os.spawn ,os.popen ,popen2。

它公开一个call()方法来调用系统命令来执行用户任务。

9.使用子进程的Check_output()方法在Python中复制文件

使用子进程check_output()方法,可以运行外部命令或程序并捕获其输出。它还支持管道。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏成长道路

selenium使用webdriver,打开浏览器

from selenium import webdriver import time driver=webdriver.Chrome() driver.m...

17430
来自专栏某熊的全栈之路

在 Google Colab 中快速实践深度学习

Colaboratory 是一个免费的 Jupyter 笔记本环境,不需要进行任何设置就可以使用,并且完全在云端运行。借助 Colaboratory,我们可以在...

16130
来自专栏大龄程序员的人工智能之路

[译]高效的TensorFlow 2.0:应用最佳实践以及有什么变化

在最近的一篇文章中,我们提到,TensorFlow 2.0经过重新设计,重点关注开发人员的工作效率、简单性和易用性。

8930
来自专栏中科院渣渣博肆僧一枚

关于python中带下划线的变量和函数的意义

1. 前带_的变量: 标明是一个私有变量, 只用于标明, 外部类还是可以访问到这个变量

10620
来自专栏侯哥的Python分享

python算法与数据结构-单链表(38)

链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表由一系列结点(链表中每一个元素称为结点)组成,结点可...

10510
来自专栏中科院渣渣博肆僧一枚

python格式化输出之format用法

相对基本格式化输出采用‘%’的方法,format()功能更强大,该函数把字符串当成一个模板,通过传入的参数进行格式化,并且使用大括号‘{}’作为特殊字符代替‘...

21830
来自专栏大龄程序员的人工智能之路

从人工智能鉴黄模型,尝试TensorRT优化

随着互联网的快速发展,越来越多的图片和视频出现在网络,特别是UCG产品,激发人们上传图片和视频的热情,比如微信每天上传的图片就高达10亿多张。每个人都可以上传,...

16040
来自专栏大龄程序员的人工智能之路

浏览器中的手写数字识别

随着TensorFlow 2.0 alpha的发布,TensorFlow.js更新到首个正式版本1.0,TensorFlow的官网也增加了TensorFlow....

24880
来自专栏大龄程序员的人工智能之路

Tensorflow SavedModel模型的保存与加载

这两天搜索了不少关于Tensorflow模型保存与加载的资料,发现很多资料都是关于checkpoints模型格式的,而最新的SavedModel模型格式则资料较...

48530
来自专栏大龄程序员的人工智能之路

利用人工智能检测色情图片

色情内容在中国一直处于严格的监管,即使这样,互联网上还是很容易就能访问到色情内容。还记得曾经的“绿坝-花季护航”软件么?由于其识别效果差、软件不稳定,最后不了了...

21720

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励