python内置模块~shutil
--High-level file operations,高级的文件操作模块~
shutil 模块的使用主要包括对文件及目录的移动、复制、打包、压缩(解压)、删除等操作。是对os模块的一个补充~
shutil.copyfileobj(fclass="lazy" data-src, fdst[, length])
复制一个文件到另一个文件。
copyfileobj函数源码:
def copyfileobj(fclass="lazy" data-src, fdst, length=16*1024):
"""copy data from file-like object fclass="lazy" data-src to file-like object fdst"""
while 1:
buf = fclass="lazy" data-src.read(length) # length 为缓冲大小
if not buf:
break
fdst.write(buf)
示例:
import shutil
f_read = open(file='/Users/luyi/tmp/a.txt', mode='r')
f_write = open(file='/Users/luyi/tmp/b.txt', mode='w')
shutil.copyfileobj(f_read, f_write)
使用 copyfileobj 进行复制略显麻烦,源文件和目标文件都需要打开(open)才能进行复制操作~
shutil.copyfile(class="lazy" data-src, dst)
同样是复制操作~
示例:
import shutil
f_class="lazy" data-src = '/Users/luyi/tmp/a.txt'
f_dest = '/Users/luyi/tmp/b.txt'
shutil.copyfile(f_class="lazy" data-src, f_dest)
相比于 copyfileobj,copyfile 实现的复制操作要简单的多,在日常的使用中,也是更多的使用 copyfile 函数。其实在内部,copyfile 函数调用了 copyfileobj函数~
shutil.copymode(class="lazy" data-src, dst)
复制文件的权限,即读写权限,不会复制源文件的内容及属主和属组~
示例:
➜ ls -l
total 16
-rw-rw-r-- 1 baby wheel 4 Nov 7 22:46 a.txt
-rw-r--r-- 1 root wheel 4 Nov 7 22:46 b.txt
>>> import shutil
>>> shutil.copymode('a.txt','b.txt')
➜ ls -l
total 16
-rw-rw-r-- 1 baby wheel 4 Nov 7 22:46 a.txt
-rw-rw-r-- 1 root wheel 4 Nov 7 22:46 b.txt
复制权限的过程,源文件和目标文件都必须存在,若目标文件不存在,则会报错。这里区别于 copyfile 函数,copyfile函数的目标文件可以存在也可以不存在,不存在则直接进行复制,若存在则进行覆盖~
➜ tmp ll
total 8
-rw-r--r-- 1 baby staff 4B Nov 6 23:48 a.txt
>>> import shutil
>>> shutil.copymode('a.txt','b.txt')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/shutil.py", line 91, in copymode
os.chmod(dst, mode)
OSError: [Errno 2] No such file or directory: 'b.txt'
shutil.copystat(class="lazy" data-src, dst)
复制文件的所有状态信息,包括 mode bits,atime,mtime,flags,但不复制文件内容,以及文件的属主和属组~
➜ ls -l
total 16
-rw-rw-r-- 1 baby wheel 4 Nov 7 22:46 a.txt
-rw-r--r-- 1 root wheel 4 Nov 7 22:50 b.txt
➜ stat a.txt
16777220 8603112152 -rw-rw-r-- 1 baby wheel 0 4 "Nov 7 22:48:16 2018" "Nov 7 22:46:22 2018" "Nov 7 22:46:46 2018" "Nov 7 22:46:06 2018" 4096 8 0 a.txt
➜ stat b.txt
16777220 8603112261 -rw-r--r-- 1 root wheel 0 4 "Nov 7 22:50:32 2018" "Nov 7 22:50:37 2018" "Nov 7 22:50:37 2018" "Nov 7 22:50:32 2018" 4096 8 0 b.txt
>>> import shutil
>>> shutil.copystat('a.txt','b.txt') # 执行复制状态操作
stat 输出的信息中包含3个时间,其中第一个是atime,第二个是mtime,最后一个是ctime。复制完成后,查看两个文件的状态信息:
➜ ls -l
total 16
-rw-rw-r-- 1 baby wheel 4 Nov 7 22:46 a.txt
-rw-rw-r-- 1 root wheel 4 Nov 7 22:46 b.txt
➜ stat a.txt
16777220 8603112152 -rw-rw-r-- 1 baby wheel 0 4 "Nov 7 22:48:16 2018" "Nov 7 22:46:22 2018" "Nov 7 22:46:46 2018" "Nov 7 22:46:06 2018" 4096 8 0 a.txt
➜ stat b.txt
16777220 8603112261 -rw-rw-r-- 1 root wheel 0 4 "Nov 7 22:48:16 2018" "Nov 7 22:46:22 2018" "Nov 7 22:52:02 2018" "Nov 7 22:46:22 2018" 4096 8 0 b.txt
可以看到源文件 a.txt 的 atime,mtime 和 mode bits 已经复制到 b.txt 上,文件的属主和属组 并没有发生变化。其中文件的 ctime 由系统自行维护~
shutil.copy(class="lazy" data-src, dst)
复制文件的内容以及权限,即先 copyfile,然后再 copymode~
shutil.copy2(class="lazy" data-src, dst)
复制文件的内容以及文件的状态信息,先 copyfile,再 copystat~
shutil.copytree(class="lazy" data-src, dst, symlinks=False, ignore=None)
递归的复制目录,以及文件的所有状态信息(不包括文件的属主和属组)
示例:
➜ ls -l test1
total 16
-rw-rw-r-- 1 baby wheel 4 Nov 7 22:46 a.txt
-rw-r--r-- 1 root wheel 4 Nov 7 22:56 b.txt
>>> import shutil
>>> shutil.copytree('test1', 'test2')
'test2'
➜ ls -l test2
total 16
-rw-rw-r-- 1 root wheel 4 Nov 7 22:46 a.txt
-rw-r--r-- 1 root wheel 4 Nov 7 22:56 b.txt
shutil.rmtree(path[, ignore_errors[, onerror]])
递归的删除文件~
示例:
➜ ls -l test1
total 16
-rw-rw-r-- 1 baby wheel 4 Nov 7 22:46 a.txt
-rw-r--r-- 1 root wheel 4 Nov 7 22:56 b.txt
>>> import shutil
>>> shutil.rmtree('test1')
rmtree相当于 rm -fr 命令,谨慎操作~
shutil.move(class="lazy" data-src, dst)
递归的移动文件,作用与通过move命令移动目录类似~
示例:
➜ tmp ll
total 0
drwxr-xr-x 4 baby staff 128B Nov 7 23:09 test
>>> import shutil
>>> shutil.move('test','/Users/luyi')
'/Users/luyi/test'
➜ tmp ll /Users/luyi/test
total 16
-rw-r--r-- 1 baby staff 4B Nov 6 23:48 a.txt
-rw-r--r-- 1 baby staff 4B Nov 7 23:06 b.txt
shutil.make_archive(base_name, format,root_dir=None,...)
打包或压缩文件,并且返回操作后的文件路径~
参数说明:
base_name:压缩包的文件名(abc.tar.gz,则base_name为abc),也可以是绝对路径;若是文件名,则压缩后的文件默认存放于当前目录,若是绝对路径,则压缩有的文件就保存到指定路径~
format:指定压缩或打包的类型,"zip","tar","bztar","gztar"
root_dir:需要压缩的文件或目录路径
owner:属主,默认为当前用户
group:属组,默认为当前组
logger:指定日志对象,通常是logging.Logger对象~
示例:
➜ tmp ll
total 0
drwxr-xr-x 4 baby staff 128B Nov 7 23:09 test
>>> import shutil
>>> shutil.make_archive(base_name='test',format='zip',root_dir='test')
'/Users/luyi/tmp/test.zip'
>>> shutil.make_archive(base_name='test',format='gztar',root_dir='test')
'/Users/luyi/tmp/test.tar.gz'
>>> shutil.make_archive(base_name='test',format='tar',root_dir='test')
'/Users/luyi/tmp/test.tar'
>>> shutil.make_archive(base_name='test',format='bztar',root_dir='test')
'/Users/luyi/tmp/test.tar.bz2'
➜ tmp ll
total 48
drwxr-xr-x 4 baby staff 128B Nov 7 23:09 test
-rw-r--r-- 1 baby staff 10K Nov 7 23:25 test.tar
-rw-r--r-- 1 baby staff 187B Nov 7 23:25 test.tar.bz2
-rw-r--r-- 1 baby staff 195B Nov 7 23:25 test.tar.gz
-rw-r--r-- 1 baby staff 206B Nov 7 23:25 test.zip
.................^_^
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341