python模块介绍- shutil 高级文件操作
python模块介绍- shutil 高级文件操作
简介
shutil模块提供了大量的文件的高级操作。特别针对文件拷贝和删除,主要功能为目录和文件操作以及压缩操作。对单个文件的操作也可参见os模块。
注意即便是更高级别的文件复制函数(shutil.copy(),shutil.copy2())也不能复制所有文件的元数据。这意味着在POSIX平台上,文件的所有者和组以及访问控制列表都将丢失。在Mac OS中资源fork和其他元数据无法使用。这意味着资源将丢失,文件类型和创建者代码将不正确。在Windows上,文件所有者,ACL和备用数据流不会被复制。
-
功能:高级文件操作。类型:标准模块相关模块:
os 标准模块。zipfile 标准模块。tarfile 标准模块。
拷贝文件
shutil.copyfile(src, dst):复制文件内容(不包含元数据)从src到dst。 DST必须是完整的目标文件名;拷贝目录参见shutil.copy()。如果src和dst是同一文件,就会引发错误shutil.Error。dst必须是可写的,否则将引发异常IOError。如果dst已经存在,它会被替换。特殊文件,例如字符或块设备和管道不能使用此功能,因为copyfile会打开并阅读文件。 src和dst的是字符串形式的路径名。
from shutil import * from glob import glob print 'BEFORE:', glob('shutil_copyfile.*') copyfile('shutil_copyfile.py', 'shutil_copyfile.py.copy') print 'AFTER:', glob('shutil_copyfile.*')
执行结果:
# python shutil_copyfile.py BEFORE: ['shutil_copyfile.py'] AFTER: ['shutil_copyfile.py', 'shutil_copyfile.py.copy'] # python shutil_copyfile.py BEFORE: ['shutil_copyfile.py', 'shutil_copyfile.py.copy']
copyfile()调用了底函数层copyfileobj()。
shutil.copyfileobj(fsrc, fdst[, length]):复制文件内容(不包含元数据)从类文件对象src到类文件对dst。可选参数length指定缓冲区的大小,负数表示一次性读入。默认会把数据切分成小块拷贝,以免占用太多内存。注意:拷贝是从fsrc的当前文件开始。
from shutil import * import os from StringIO import StringIO import sys class VerboseStringIO(StringIO): def read(self, n=-1): next = StringIO.read(self, n) print 'read(%d) bytes' % n return next lorem_ipsum = '''Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Vestibulum aliquam mollis dolor. Donec vulputate nunc ut diam. Ut rutrum mi vel sem. Vestibulum ante ipsum.''' print 'Default:' input = VerboseStringIO(lorem_ipsum) output = StringIO() copyfileobj(input, output) print print 'All at once:' input = VerboseStringIO(lorem_ipsum) output = StringIO() copyfileobj(input, output, -1) print print 'Blocks of 256:' input = VerboseStringIO(lorem_ipsum) output = StringIO() copyfileobj(input, output, 256)
执行结果:
# python shutil_copyfileobj.py Default: read(16384) bytes read(16384) bytes All at once: read(-1) bytes read(-1) bytes Blocks of 256: read(256) bytes read(256) bytes
shutil.copy(src, dst):复制文件src到文件或目录dst。如果dst是目录,使用src相同的文件名创建(或覆盖),权限位也会复制。src和dst的是字符串形式的路径名。
from shutil import * import os os.mkdir('example') print 'BEFORE:', os.listdir('example') copy('shutil_copy.py', 'example') print 'AFTER:', os.listdir('example')
执行结果:
# python shutil_copy.py BEFORE: [] AFTER: ['shutil_copy.py'
shutil.copy2(src, dst):类似shutil.copy,元数据也复制,实际上先调用shutil.copy,然后使用copystat。这类似于Unix命令cp -p。
from shutil import * import os import time def show_file_info(filename): stat_info = os.stat(filename) print '\tMode :', stat_info.st_mode print '\tCreated :', time.ctime(stat_info.st_ctime) print '\tAccessed:', time.ctime(stat_info.st_atime) print '\tModified:', time.ctime(stat_info.st_mtime) os.mkdir('example') print 'SOURCE:' show_file_info('shutil_copy2.py') copy2('shutil_copy2.py', 'example') print 'DEST:' show_file_info('example/shutil_copy2.py')
执行结果:
# python shutil_copy2.py SOURCE: Mode : 33279 Created : Fri Dec 6 10:45:52 2013 Accessed: Fri Dec 6 11:49:40 2013 Modified: Mon Feb 21 01:37:46 2011 DEST: Mode : 33279 Created : Fri Dec 6 11:51:58 2013 Accessed: Fri Dec 6 11:49:40 2013 Modified: Mon Feb 21 01:37:46 2011
shutil.ignore_patterns(*patterns) 为copytree的辅助函数,提供glob功能,示例:
from shutil import copytree, ignore_patterns copytree(source, destination, ignore=ignore_patterns('*.pyc', 'tmp*'))
拷贝文件元数据
下面部分删除,参见下面的本文地址
压缩解压
下面部分删除,参见下面的本文地址
本文地址
-
http://automationtesting.sinaapp.com/blog/m_shutil
参考资料
-
http://docs.python.org/2/library/shutil.html?http://zh.wikipedia.org/wiki/Base64?http://pymotw.com/2/shutil/?http://effbot.org/librarybook/shutil.htm
评论关闭