Python中的shutil标准库用法解析
1.文件夹与文件操作
copyfileobj(fsrc, fdst, length=16*1024): 将fsrc文件内容复制至fdst文件,length为fsrc每次读取的长度,用做缓冲区大小
- fsrc: 源文件
- fdst: 复制至fdst文件
- length: 缓冲区大小,即fsrc每次读取的长度
import shutil f1 = open('shutil1.txt', 'r', encoding='utf-8') f2 = open('shutil2.txt', 'a+', encoding='utf-8') shutil.copyfileobj(f1, f2, length=512)
copyfile(src, dst): 将src文件内容复制至dst文件
- src: 源文件路径
- dst: 复制至dst文件,若dst文件不存在,将会生成一个dst文件;若存在将会被覆盖
- follow_symlinks:设置为True时,若src为软连接,则当成文件复制;如果设置为False,复制软连接。默认为True。Python3新增参数
# copyfile(src, dst): 将src文件内容复制至dst文件 import shutil shutil.copy('shutil1.txt', 'shutil1_copy.txt')
copymode(src, dst): 将src文件权限复制至dst文件。文件内容,所有者和组不受影响
- src: 源文件路径
- dst: 将权限复制至dst文件,dst路径必须是真实的路径,并且文件必须存在,否则将会报文件找不到错误
- follow_symlinks:设置为False时,src, dst皆为软连接,可以复制软连接权限,如果设置为True,则当成普通文件复制权限。默认为True。Python3新增参数
# copymode(src, dst)将src文件权限复制至dst文件。 import shutil shutil.copymode("file.txt","file_copy.txt")
copy(src, dst): 将文件src复制至dst。dst可以是个目录,会在该目录下创建与src同名的文件,若该目录下存在同名文件,将会报错提示已经存在同名文件。权限会被一并复制。本质是先后调用了copyfile与copymode而已
- src:源文件路径
- dst:复制至dst文件夹或文件
- follow_symlinks:设置为False时,src, dst皆为软连接,可以复制软连接权限,如果设置为True,则当成普通文件复制权限。默认为True。Python3新增参数
# copy(src, dst)**: 将文件src复制至dst。dst可以是个目录 import shutil import os shutil.copy("file.txt","file_copy.txt") # 或者 shutil.copy("file.txt",os.path.join(os.getcwd(),"copy")) # os.getcwd()获取当前工作目录
copytree(src, dst, symlinks=False, ignore=None): 拷贝文档树,将src文件夹里的所有内容拷贝至dst文件夹
- src:源文件夹
- dst:复制至dst文件夹,该文件夹会自动创建,需保证此文件夹不存在,否则将报错
- symlinks:是否复制软连接,True复制软连接,False不复制,软连接会被当成文件复制过来,默认False
- ignore:忽略模式,可传入ignore_patterns()
- copy_function:拷贝文件的方式,可以传入一个可执行的处理函数,默认为copy2,Python3新增参数
- ignore_dangling_symlinks:sysmlinks设置为False时,拷贝指向文件已删除的软连接时,将会报错,如果想消除这个异常,可以设置此值为True。默认为False,Python3新增参数
- ignore_patterns(*patterns): 忽略模式,用于配合copytree()方法,传递文件将会被忽略,不会被拷贝。patterns:文件名称,元组
import shutil,os folder1 = os.path.join(os.getcwd(),"aaa") # bbb与ccc文件夹都可以不存在,会自动创建 folder2 = os.path.join(os.getcwd(),"bbb","ccc") # 将"abc.txt","bcd.txt"忽略,不复制 shutil.copytree(folder1,folder2,ignore=shutil.ignore_patterns("abc.txt","bcd.txt")
rmtree(path, ignore_errors=False, οnerrοr=None): 移除文档树,将文件夹目录删除
- ignore_errors:是否忽略错误,默认False
- onerror:定义错误处理函数,需传递一个可执行的处理函数,该处理函数接收三个参数:函数、路径和excinfo
import shutil,os folder1 = os.path.join(os.getcwd(),"aaa") shutil.rmtree(folder1)
move(src, dst): 将src移动至dst目录下。若dst目录不存在,则效果等同于src改名为dst。若dst目录存在,将会把src文件夹的所有内容移动至该目录下面
- src:源文件夹或文件
- dst:移动至dst文件夹,或将文件改名为dst文件。如果src为文件夹,而dst为文件将会报错
- copy_function:拷贝文件的方式,可以传入一个可执行的处理函数。默认为copy2,Python3新增参数
import shutil,os # 示例一,将src文件夹移动至dst文件夹下面,如果bbb文件夹不存在,则变成了重命名操作 folder1 = os.path.join(os.getcwd(),"aaa") folder2 = os.path.join(os.getcwd(),"bbb") shutil.move(folder1, folder2) # 示例二,将src文件移动至dst文件夹下面,如果bbb文件夹不存在,则变成了重命名操作 file1 = os.path.join(os.getcwd(),"aaa.txt") folder2 = os.path.join(os.getcwd(),"bbb") shutil.move(file1, folder2) # 示例三,将src文件重命名为dst文件(dst文件存在,将会覆盖) file1 = os.path.join(os.getcwd(),"aaa.txt") file2 = os.path.join(os.getcwd(),"bbb.txt") shutil.move(file1, file2)
2.归档操作
shutil还提供了创建和读取压缩和存档文件的高级使用程序。内部实现主要依靠的是zipfile和tarfile模块
make_archive(base_name, format, root_dir, …): 生成压缩文件
- base_name:压缩文件的文件名,不允许有扩展名,因为会根据压缩格式生成相应的扩展名
- format:压缩格式:“zip”, “tar”, “bztar”,“gztar”
- root_dir:将指定文件夹进行压缩
# 将当前工作目录下的make_archive文件夹里面的内容打包zip格式,保存到当前工作目录下(并给压缩包起名为shutil1) import shutil import os base_name = os.path.join(os.getcwd(), 'shutil1') # 压缩包的文件名,也可以是压缩包的路径。只是文件名时,则保存至当前目录,否则保存至指定路径。 format = 'zip' # 压缩包种类:“zip”, “tar”, “bztar”,“gztar” root_dir = os.path.join(os.getcwd(), 'make_archive') # 要压缩的文件夹路径 shutil.make_archive(base_name, format, root_dir) # 将当前工作目录下的make_archive文件夹里面的内容打包zip格式,起名为abc,保存到当前工作目录下(没有拼接路径所以默认当前工作目录) import shutil import os base_name = 'abc' # 压缩包的文件名,也可以是压缩包的路径。只是文件名时,则保存至当前目录,否则保存至指定路径。 format = 'zip' # 压缩包种类:“zip”, “tar”, “bztar”,“gztar” root_dir = os.path.join(os.getcwd(), 'make_archive') # 要压缩的文件夹路径 shutil.make_archive(base_name, format, root_dir)
- get_archive_formats(): 获取支持的压缩文件格式。目前支持的有:tar、zip、gztar、bztar。在Python3还多支持一种格式xztar
unpack_archive(filename, extract_dir=None, format=None): 解压操作。Python3新增方法
- filename:文件路径
- extract_dir:解压至的文件夹路径。文件夹可以不存在,会自动生成
- format:解压格式,默认为None,会根据扩展名自动选择解压格式
# 将当前目下下的abc.zip解压缩到当前目录并将解压缩后的文件夹更名为aaa import shutil import os zip_path = os.path.join(os.getcwd(), 'abc.zip') extract_dir = os.path.join(os.getcwd(), 'aaa') shutil.unpack_archive(zip_path, extract_dir)
- get_unpack_formats(): 获取支持的解压文件格式。目前支持的有:tar、zip、gztar、bztar和xztar。Python3新增方法
到此这篇关于Python中的shutil标准库用法解析的文章就介绍到这了,更多相关Python的shutil内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
最新评论