python标准库之shutil——可操作权限的文件操作库
转载自:https://www.jb51.net/article/145522.htm
shutil模块提供了许多关于文件和文件集合的高级操作,特别提供了支持文件复制和删除的功能。
文件夹与文件操作
copyfileobj(fsrc, fdst, length=16*1024): 将fsrc文件内容复制至fdst文件,length为fsrc每次读取的长度,用做缓冲区大小
- fsrc: 源文件
- fdst: 复制至fdst文件
- length: 缓冲区大小,即fsrc每次读取的长度
1
2
3
4
|
import shutil f1 = open ( "file.txt" , "r" ) f2 = open ( "file_copy.txt" , "a+" ) shutil.copyfileobj(f1,f2,length = 1024 ) |
copyfile(src, dst): 将src文件内容复制至dst文件
- src: 源文件路径
- dst: 复制至dst文件,若dst文件不存在,将会生成一个dst文件;若存在将会被覆盖
- follow_symlinks:设置为True时,若src为软连接,则当成文件复制;如果设置为False,复制软连接。默认为True。Python3新增参数
1
2
|
import shutil shutil.copyfile( "file.txt" , "file_copy.txt" ) |
copymode(src, dst): 将src文件权限复制至dst文件。文件内容,所有者和组不受影响
- src: 源文件路径
- dst: 将权限复制至dst文件,dst路径必须是真实的路径,并且文件必须存在,否则将会报文件找不到错误
- follow_symlinks:设置为False时,src, dst皆为软连接,可以复制软连接权限,如果设置为True,则当成普通文件复制权限。默认为True。Python3新增参数
1
2
|
import shutil shutil.copymode( "file.txt" , "file_copy.txt" ) |
copystat(src, dst): 将权限,上次访问时间,上次修改时间以及src的标志复制到dst。文件内容,所有者和组不受影响
- src: 源文件路径
- dst: 将权限复制至dst文件,dst路径必须是真实的路径,并且文件必须存在,否则将会报文件找不到错误
- follow_symlinks:设置为False时,src, dst皆为软连接,可以复制软连接权限、上次访问时间,上次修改时间以及src的标志,如果设置为True,则当成普通文件复制权限。默认为True。Python3新增参数
1
2
|
import shutil shutil.copystat( "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新增参数
1
2
3
4
|
improt shutil,os shutil.copy( "file.txt" , "file_copy.txt" ) # 或者 shutil.copy( "file.txt" ,os.path.join(os.getcwd(), "copy" )) |
copy2(src, dst): 将文件src复制至dst。dst可以是个目录,会在该目录下创建与src同名的文件,若该目录下存在同名文件,将会报错提示已经存在同名文件。权限、上次访问时间、上次修改时间和src的标志会一并复制至dst。本质是先后调用了copyfile与copystat方法而已
- src:源文件路径
- dst:复制至dst文件夹或文件
- follow_symlinks:设置为False时,src, dst皆为软连接,可以复制软连接权限、上次访问时间,上次修改时间以及src的标志,如果设置为True,则当成普通文件复制权限。默认为True。Python3新增参数
1
2
3
4
|
improt shutil,os shutil.copy2( "file.txt" , "file_copy.txt" ) # 或者 shutil.copy2( "file.txt" ,os.path.join(os.getcwd(), "copy" )) |
ignore_patterns(*patterns): 忽略模式,用于配合copytree()
方法,传递文件将会被忽略,不会被拷贝
- patterns:文件名称,元组
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新增参数
1
2
3
4
5
6
|
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, onerror=None): 移除文档树,将文件夹目录删除
- ignore_errors:是否忽略错误,默认False
- onerror:定义错误处理函数,需传递一个可执行的处理函数,该处理函数接收三个参数:函数、路径和excinfo
1
2
3
|
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新增参数
1
2
3
4
5
6
7
8
9
10
11
12
13
|
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) |
disk_usage(path): 获取当前目录所在硬盘使用情况。Python3新增方法
- path:文件夹或文件路径。windows中必须是文件夹路径,在linux中可以是文件路径和文件夹路径
1
2
3
4
|
import shutil.os path = os.path.join(os.getcwd(), "aaa" ) info = shutil.disk_usage(path) print (info) # usage(total=95089164288, used=7953104896, free=87136059392) |
chown(path, user=None, group=None): 修改路径指向的文件或文件夹的所有者或分组。Python3新增方法
- path:路径
- user:所有者,传递user的值必须是真实的,否则将报错no such user
- group:分组,传递group的值必须是真实的,否则将报错no such group
1
2
3
|
import shutil,os path = os.path.join(os.getcwd(), "file.txt" ) shutil.chown(path,user = "root" ,group = "root" ) |
which(cmd, mode=os.F_OK | os.X_OK, path=None): 获取给定的cmd命令的可执行文件的路径。Python3新增方法
1
2
3
|
import shutil info = shutil.which( "python3" ) print (info) # /usr/bin/python3 |
归档操作
shutil还提供了创建和读取压缩和存档文件的高级使用程序。内部实现主要依靠的是zipfile和tarfile模块
make_archive(base_name, format, root_dir, …): 生成压缩文件
- base_name:压缩文件的文件名,不允许有扩展名,因为会根据压缩格式生成相应的扩展名
- format:压缩格式
- root_dir:将制定文件夹进行压缩
1
2
3
4
5
6
|
import shutil,os base_name = os.path.join(os.getcwd(), "aaa" ) format = "zip" root_dir = os.path.join(os.getcwd(), "aaa" ) # 将会root_dir文件夹下的内容进行压缩,生成一个aaa.zip文件 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,会根据扩展名自动选择解压格式
1
2
3
4
|
import shutil,os zip_path = os.path.join(os.getcwd(), "aaa.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爬虫与数据分析之进阶教程:文件操作、lambda表达式、递归、yield生成器
专栏目录: Python爬虫与数据分析之python教学视频.python源码分享,python Python爬虫与数据分析之基础教程:Python的语法.字典.元组.列表 Python爬虫与数据分析 ...
- 背水一战 Windows 10 (90) - 文件系统: 获取 Package 中的文件, 可移动存储中的文件操作, “库”管理
[源码下载] 背水一战 Windows 10 (90) - 文件系统: 获取 Package 中的文件, 可移动存储中的文件操作, “库”管理 作者:webabcd 介绍背水一战 Windows 10 ...
- Python全栈之路4--内置函数--文件操作
上节重点回顾: 判断对象是否属于某个类,例如: 列表中有个数字,但是循环列表判断长度,用len会报错;因为int不支持len,所以要先判断属于某个类,然后再进行if判断. # isinstance(对 ...
- python基础知识-7-内存、深浅、文件操作
python其他知识目录 1.一些对内存深入理解的案例 以下列举列表,列表/字典/集合这些可变类型都是一样的原理 变量是个地址,指向存储数据的内存空间的地址,它的实质就相当于c语言里的指针.变量和数据 ...
- Python开发【第三章】:文件操作
一.文件操作模式概述 1.打开文件的模式: r, 只读模式[默认] w,只写模式[不可读:不存在则创建:存在则删除内容:] a, 追加模式[不可读:不存在则创建:存在则只追加内容:] 2." ...
- python反转字符串(简单方法)及简单的文件操作示例
Python反转字符串的最简单方法是用切片: >>> a=' >>> print a[::-1] 654321 切片介绍:切片操作符中的第一个数(冒号之前)表示切片 ...
- Python 基础篇:字典、集合、文件操作
字典 字典一种key - value 的数据类型 1. 语法: info = { 'stu1101': "TengLan Wu", 'stu1102': "LongZe ...
- [Linux]目录x权限对文件操作的影响
问题 我们常使用linux以下命令 cd 进入目录 ls 列出目录中的文件 或者直接打开目录中的文件 以上操作对于目录权限位的设置来说,是有一定迷惑性的,如表格所示 cd进入该目录 cd进入该目录 ...
- python自动化开发-[第三天]-编码,函数,文件操作
今日概要 - 编码详解 - 文件操作 - 初识函数 一.字符编码 1.代码执行过程 代码-->解释器翻译-->机器码-->执行 2.ASCII ASCII:一个Bytes代表一个字符 ...
随机推荐
- java读取 xml文件
java读取xml文件的四种方法 转自https://www.cnblogs.com/lingyao/p/5708929.html Xml代码 1 <?xml version="1. ...
- could not load file or assembly "System.Web.Mvc...
1.一般出现这个错误是因为Web.Config里面的版本号跟project用到的dll版本对应不上 更改webconfig <add assembly="System.Web.Mvc, ...
- BERT中文 添加 early_stop
Step1:建一个hook early_stopping_hook = tf.contrib.estimator.stop_if_no_decrease_hook( estimator=estimat ...
- Neo4j 简介 2019
Neo4j是一个世界领先的开源图形数据库,由 Java 编写.图形数据库也就意味着它的数据并非保存在表或集合中,而是保存为节点以及节点之间的关系. Neo4j 的数据由下面几部分构成: 节点边属性Ne ...
- ARTS打卡计划第十四周
Algorithms: https://leetcode-cn.com/problems/best-time-to-buy-and-sell-stock/ Review: “How to write ...
- 解惑spring事务传播特性之嵌套事务
/** * Support a current transaction, create a new one if none exists. * Analogous to EJB transaction ...
- JS各循环的差别
1.最普通的for循环: for(var i=0;i<arr.length;i++){ } 特点:只能针对数组循环,不能引用于非数组对象 2.for(var i in obj){ } 特点:用于 ...
- 解决spring-boot 各版本包冲突兼容的方法
思路 在微服务盛行的当下,spring boot 流行程度已经家喻户晓.但同时,随着spring boot 快速迭代,出现了很多版本,比如当前已经推出了2.2.x-SNAPSHOT/ , ...
- legend3---9、项目的日志以及调试信息数据量非常大
legend3---9.项目的日志以及调试信息数据量非常大 一.总结 一句话总结: legend2我开发调试,最近竟然发现日志等的信息有1.5G,数据量实在太大 1.juqery如何找后代? chil ...
- C# Read/Write another Process' Memory
https://codingvision.net/security/c-read-write-another-process-memory Today’s tutorial is about…proc ...