shutil复制粘贴和压缩

shutil

高级的文件、文件夹、压缩包处理模块

@1)、将文件内容拷贝到另一个文件中

    import shutil
shutil.copyfileobj(open("1.txt",'r'), open('2.txt','w'))

@2)、拷贝文件

    import shutil
shutil.copyfile('f1.log','f2.log')

@3)、仅拷贝权限。内容、组、用户不变

    shutil.copymode('f1.log','f2.log')  

@4)、拷贝状态的信息,包括:mode bits ,atime(文件防伪时间), mtime, flags

shutil.copystat('f1.log','f2.log') 

@5)、 拷贝文件和权限

    shutil.copy(src,dst)
import shutil
shutil.copy('f1.log', 'f2.log')

@6)、拷贝文件和状态信息

    import shutil
shutil.copy2('f1.log', 'f2.log')

@7)、递归的去拷贝文件夹

    shutil.ignore_patterns(*patterns)
shutil.copytree(src,dst, symlinks=False, ignoer=None)
案例:
import shutil
shutil.copytree('folder1', 'folder2', ignore=shutil.ignore_patterns("*.py", "tmp*")) #(ignore忽略)

@8)、递归的去删除文件

    shutil.retree(path[,ignore_errors[,onerror]])
import shutil
shutil.retree('folder1')

@9)、递归的去移动文件,它类似mv命令,其实就是重命令

    import shutil
shutil.move('folder1', 'folder3')

压缩和解压

@10)、shutil.make_archive(base_name, format,...)
创建压缩包并返回文件路径, 例如:zip, tar

    a]· base_name :压缩包的文件名,也可以是压缩包路径。只是文件名时,则保持至当前目录,否则保存至指定路径
如:www -->保存至当前路径
如:/Users/local/www -->保存至/users/local
b]. format:压缩包种类,"zip,tar,bztar,gztar"
c]. root_dir :要压缩的文件夹路径(默认当前目录)
d]. owner: 用户,默认当前用户
d]. group:组,默认当前组
e]. logger:用于记录日志,通常是logging.Logger对象

案例一:

压缩
#将/usr/local/lownloads/test下的文件打包放置当前程序目录

    import shutil
ret = shutil.make_archive("www", 'gztar', root_dir = "/usr/local/downloads/test")
#将/usr/local/downsload/test 下的文件打包方放置在/usr/loca/目录
import shutil
ret = shutil.make_archive("/usr/local/www", 'gztar', root_dir='usr/local/downsload/test')
f].shutil对压缩包的处理是调用ZipFile和TarFile两个模块来进行的,详细:
import zipfile
#压缩
    z = zipfile.ZipFile('laxi.zip', 'w')
z.write('a.log')
z.write('data.data')
z.close()

#解压

    z = zipfile.ZipFile('lai.zip','r')
z.extractall()
z.close()

import tarfile
    #压缩

    tar = tarfile.open('your.tar','w')
tar.add('/usr/local/pycharm/bbs2.log', arcname='bbs2.log')
tar.add('/usr/local/pycharm/cmd.log', arcname='cmd.log')
tar.close()

#解压

    tar = tarfile.open('your.tar', 'r')
tar.extractall() #可设置解压地址
tar.close()

shutil复制粘贴和压缩的更多相关文章

  1. Revealjs网页版PPT让你复制粘贴另类装逼,简洁优雅又低调,不懂编程也看过来

    Revealjs网页版PPT让你复制粘贴另类装逼,简洁优雅又低调,不懂编程也看过来 要了解一个新知识我们可以从三个方面入手:是什么,有什么用,怎么用.下面我们就从这三个方面进行讲解Reveal.js噢 ...

  2. Android中的复制粘贴

    Android中的复制粘贴 The Clipboard Framework 当使用clipboard framework时,把数据放在一个剪切对象(clip object)里,然后这个对象会放在系统的 ...

  3. 远程桌面时plsql的复制粘贴功能失效

    解决办法:重新启动远程桌面上的rdpclip进程就可以复制粘贴了,但是每次重开远程桌面都会出现同样的问题.可以rdpclip这个设置成开机启动.

  4. 不注册COM在Richedit中使OLE支持复制粘贴

    正常情况下在Richedit中使用OLE,如果需要OLE支持复制粘贴,那么这个OLE对象必须是已经注册的COM对象. 注册COM很简单,关键问题在于注册时需要管理员权限,这样一来,如果希望APP做成绿 ...

  5. ios textfield / textview长按复制粘贴中文显示

    当我们在写应用时要复制粘贴文本框内容时,默认显示的文字为英文字体,可按如下步骤设置,显示中文:

  6. 复制粘贴出来的悲剧----spring实现文件下载和HttpStatus.CREATED

    今天真是被自己的懒惰和复制粘贴给坑惨了... 网上有这么一个spring下载文件的最佳实践: @RequestMapping("download") public Response ...

  7. ZeroClipboard跨浏览器复制粘贴

    <!DOCTYPE html> <html> <head> <title>ZeroClipboard跨浏览器复制粘贴</title> < ...

  8. ubuntu快捷复制粘贴

    今天使用putty,纠结复制粘贴的时候,才发现 原来只要选中文本后,就可以中键粘贴 整个桌面环境可用,新技能啊以前居然不知道

  9. firefox浏览器不支持复制粘贴(linux)

    在Linux主机下使用firefox在线编辑文章时,提示不支持复制粘贴选项,并给出了解决方法,记录一下 1.先找到本机firefox的配置文件的所在文件夹位置,不知道的请遵循以下步骤 点击菜单栏的帮助 ...

随机推荐

  1. HTML 学习笔记 JavaScript (prototype)

    原博地址:http://www.cnblogs.com/dolphinX/p/3286177.html 原博客的作者是一个非常牛逼的前端大神,我作为一个初学者,在此借助大神的博客进行自己的学习.在这里 ...

  2. 从数据库导出到excel

    在项目 扬中 News shenbaocreateall //选中的id string cc = Request["IDcheck"];            Response.C ...

  3. 软件工程导论-目录-K-T+RJ大

    目录 10 第1章 软件工程学概述/1 19 1.1 软件危机/1 19 1.1.1 软件危机的介绍/1 19 1.1.2 产生软件危机的原因/3 21 1.1.3 消除软件危机的途径/4 22 1. ...

  4. 让所有的浏览器都能识别HTML5标签样式的小插件

    如今HTML5愈来愈引发大家的关注了,但目前支持HTML5的浏览器还不是主流,特别是国内用户近50%以上仍旧使用IE6,由于支持HTML5的IE9不支持Xp系统安装,这样未来很长一段时间,HTML5的 ...

  5. 安卓开发:一种快速提取安卓app的UI图标资源的方法

    在做安卓设计时,找美工设计界面的漂亮图标是必不可少的,但是对于一个初创团队来说,请一个UI的成本其实也挺高的,此时对于一个偏技术的产品经理来说,从其他成熟的产品的apk中提取图标就是一个很便捷的方法, ...

  6. 格雷码原理与Verilog实现

    格雷码原理 格雷码是一个叫弗兰克*格雷的人在1953年发明的,最初用于通信.格雷码是一种循环二进制码或者叫作反射二进制码.格雷码的特点是从一个数变为相邻的一个数时,只有一个数据位发生跳变,由于这种特点 ...

  7. 基于Xenomai的实时Linux分析与研究

    转自:http://blog.csdn.net/cyberlabs/article/details/6967192 引 言 随着嵌入式设备的快速发展,嵌入式设备的功能和灵活性要求越来越高,很多嵌入式设 ...

  8. 使用 antd Table组件, 异步获取数据

    使用React.js + Redux + antd 制作CMS 后台内容管理系统,分享一点点积累,欢迎讨论. 在this.state中初始化数据: this.state = { pageNum:1, ...

  9. Hibernate连接数据库超时设置autoReconnect=true

    如果连接闲置8小时 (8小时内没有进行数据库操作), mysql就会自动断开连接, 要重启tomcat. 不用hibernate的话, connection url加参数: autoReconnect ...

  10. C# 6.0 新特性

    1.C# 6.0 示例 1: 自动属性支持初始化, 字符串嵌入的新方式, 通过 Using Static 引用静态类, nameof 表达式CSharp6/Demo1.xaml.cs /* * C# ...