以下是演示“如何在Python中复制文件”的九种方法。
- shutil copyfile()方法
- shutil copy()方法
- shutil copyfileobj()方法
- shutil copy2()方法
- os popen方法
- os系统()方法
- Thread()方法
- 子进程调用()方法
- 子进程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()方法,可以运行外部命令或程序并捕获其输出。它还支持管道。