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
- 基本格式
- 行分隔符为\r\n,最后一行可以没有分隔符
- 列分隔符通常为都好或者制表符
- 每一行称为一条记录(record)
- 字段可以使用双引号括起来,也可不用。如果字段中出现了双引号、逗号、换行符必须使用双引号括起来。如果字段的值是双引号,使用两个双引号表示一个转义
- 表头可以写也可不写,和字段列对齐就行
- 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。
- reader(csvfile,dialect=’excel’,**fmtparams)返回DictReader的实例,是个行迭代器。dellimiter列分隔符”,”逗号;lineterminator行分隔符”\r\n”;quotechar字段的引用符号,缺省为‘”’双引号
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