Python

Python中os和shutil模块
csv文件和ini文件简介

OS模块

  • os.name #windows返回结果是nt,Linux是posix。
  • os.uname() #linux支持显示
  • sys.platform #windows显示win32,linux显示linux
  • os.listdir() #返回目录内容列表
  • os也有open、read、write等方法,但是建议使用内建函数
  • os.stat(path,*,dir_fd=None,follow_symlinks=True)#调用linux系统的stat
    • path:路径的string或者bytes,或者fd
    • follow_symlink=True返回文件本身信息,False且如果是软连接则显示软连接本身
  • 改变文件的属主、属组,但需要足够的权限
    • os.chmod(path,mode,*,dir_fd=None,follow_symlinks=True)
    • os.chown(path,uid,gid)

shutil模块

python中提供的高级文件操作的库shutil

  • copyfileobj(fsrc,fdst[,length])文件对象复制,fsrc和fdst是open打开的文件对象,复制内容。fdst要求可写。length表示buffere的大小
  • copyfile(src,dst,*,follow_symlinks=True)复制文件内容,不包含元数据。src,dst为文件的路径字符串。然而本质上调用就是copyfileobj,所以不带元数据二进制内容复制
  • copymode(src,dst,*,follow_symlinks=True)仅仅复制权限
  • copystat(src,dst,*,follow_symlinks=True)复制元数据,stat包含权限
  • copy(src,dst,*,follow_symlinks=True)复制文件内容、权限和部分元数据,不包括创建时间和修改时间。本质上调用copyfile和copymode
  • copy2比copy多复制了元数据,但需要平台支持。本质调用copyfile和copystat
  • copytree(src,dst,symlinks=False,ignore=None,copy_functions=copy2,ignore_dangling_symlinks=False)递归复制目录。默认使用copy2,也就是带更多的元数据复制。
    • src、dst必须是目录,src必须存在,dst必须不存在
    • ignore=func,提供一个callable(src,names)->ignored_names。提供一个函数,他会被调用。src是源目录,那么谁是os.listdir(src)的结果,就是列出src中的文件名,返回值是要被过滤的文件名的set类型数据。
  • rm删除
    • shutil.rmtree(path,ignore_errors=False,onerror=None)递归删除。如同rm -rf一样危险,慎用。它不是原子操作,有可能删除错误就会中断,已经删除的就删除了。ignore_errors=True,忽略错误;当等于False或者omitted时onerror生效。onerror=callable,接受函数function、path和execinfo。
  • move移动
    • move(src,dst,copy_function=copy2)递归移动文件、目录到目标,返回目标。本身使用的是os.rename方法。如果不支持rename,是目录则像copytree再删除src目录
  • shutil还有打包功能,生成tar并压缩。支持zip、gz、bz、xz。

csv文件

Csv文件简介:全称Comma-Separated Values(逗号分隔值),也叫字符分隔值。它是一个被行分隔符、列分隔符划分成行和列的文本文件,没有指定字符编码。http://www.itef.org/rfc/rfc4180.txt

  • 基本格式
    1. 行分隔符为\r\n,最后一行可以没有分隔符
    2. 列分隔符通常为都好或者制表符
    3. 每一行称为一条记录(record)
    4. 字段可以使用双引号括起来,也可不用。如果字段中出现了双引号、逗号、换行符必须使用双引号括起来。如果字段的值是双引号,使用两个双引号表示一个转义
    5. 表头可以写也可不写,和字段列对齐就行
  • csv模块
    • reader(csvfile,dialect=’excel’,**fmtparams)返回DictReader的实例,是个行迭代器。dellimiter列分隔符”,”逗号;lineterminator行分隔符”\r\n”;quotechar字段的引用符号,缺省为‘”’双引号
      树荫好的处理:
      doublequote双引号的处理,默认为True。如果和quotechar为同一个,True则使用两个双引号表示;False表示使用转义字符将作为双引号的前缀。escapechar一个转义字符,默认为None。quoting制动双引号的规则。QUOTE_ALL所有字段;QUOTE_MINIMAL特殊字符字段;QUOTE_NONNUMRIC非数字字段;QUOte_NONE都不使用引号
    • write(csvfile,dialect=’excel’,**fmtparams)返回DictWriter的实例。主要方法有writerow、writerows。

ini文件处理

作为配置文件,ini文件格式的很流行。

  • 中括号里面的部分称为section。
  • 每一个section内,都是key=value形成的键值对,key称为option选项。
[DEFAULT]
a=test

[mysql]
default-character-set=utf8

[mysqld]
datadir = /dbserver/data
port = 3306
character-set-server = utf8
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

ConfigParser

configparser模块的ConfigParser类就是用来操作ini文件的

  • read(filenames,encoding=None)读取ini文件,可以是单个文件,也可以是文件列表。可以指定文件编码。
  • sections()返回section列表。缺省section不包括在内。
  • add_section(section_name)增加一个section
  • has_section(section_name)判断section是否存在
  • options(section)返回section的所有option
  • has_option(section)判断section是否存在这个option
  • get(section,option,*,raw=False,vars=None[,fallback])从指定的段的选项上去之,如果找到返回,如果没有找到就去default段查看有没有
  • getint(section,option,*,raw=False,vars=None[,fallback])和get方法一样返回指定类型数据。
  • getfloat(section,option,*,raw=False,vars=None[,fallback])和get方法一样返回指定类型数据。
  • getboolean(section,option,*,raw=False,vars=None[,fallback])和get方法一样返回指定类型数据。
  • items(raw=False,vars=None)返回所有section名字及其对象
  • items(section,raw=False,vars=None)返回这个section的键值对组成二元组。
  • set(section,option,value)section存在的情况系啊,写入option=value,要求option、value必须是字符串。
  • remove_section(section)移除section及其所有option
  • remove_option(section,option)移除section下的option
  • write(fileobj,sace_around_delimiters=True)将当前config的所有内容写入fileobj中,一般open函数使用w模式

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/88165

(0)
KX_ilKX_il
上一篇 2017-10-30
下一篇 2017-10-30

相关推荐

  • DNS服务器类型及查询过程

    什么是DNS   DNS(Domain Name System,域名系统),因特网上作为域名和IP地址相互映射的一个分布式数据库,能够使用户更方便的访问互联网,而不用去记住能够被机器直接读取的IP数串。通过主机名,最终得到该主机名对应的IP地址的过程叫做域名解析(或主机名解析)。 DNS域名称   域名系统作为一个层次结构和分布式数据库,包含各种类型的数据,…

    Linux干货 2017-02-08
  • 系统管理之作业管理与计划任务

    作业管理: Linux的作业控制(job )     前台作业:通过终端启动,且启动后一直占据终端;     后台作业:可通过终端启动,但启动后即转入后台运行(释放终端) 如何让作业运行于后台?     (1) 运行中的…

    Linux干货 2016-09-13
  • Linux的基础文件管理命令

    Linux用于管理文件的一些基本常见的命令如下: ls:  列出指定目录下的清单    -a  显示所有文件包括隐藏文件    -l  显示文件的详细信息    -d  查看目录自身   示例: cat:  可查看指定路径下的文件文本 fi…

    Linux干货 2016-11-06
  • 10yum源的配置

    yum仓库使用起来特别方便,然而使用之前当然是要配置的啦。下面就介绍一下怎么从0 配置一个yum仓库。 首先要创建yum仓库,当然不能使只给一台服务器用,那要给多个服务器用的话,就需要网络服务。yum仓库支持的网络服务有两种,FTP和HTTP。用yum主要用到的是数据传输,因此FTP更适合创建yum仓库,下面就以FTP为例,说明一下yum仓库的配置。 第一步…

    Linux干货 2016-11-04
  • 编译安装httpd-2.4.9及新特性详解

    前言 前面我们讲解了httpd在CentOS6上(httpd-2.2)的相关功能配置,而CentOS7上采用了httpd-2.4的版本,那么httpd-2.4增加了哪些特性呢?接下来让我们在CentOS6.6上手动编译安装一下httpd-2.4.9,看一下和httpd-2.2有什么不同,顺便补充说一下httpd的其它功能。 环境及新特性介绍 环境介绍 系统环…

    Linux干货 2015-04-15