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)
上一篇 2017-10-30 11:35
下一篇 2017-10-30 20:02

相关推荐

  • 马哥教育网络班21期+第4周课程练习

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 # cp -a /etc/skel /home/tuser1 # chmod -R g-rwx,o-rwx /home/tuser1/ 2、编辑…

    Linux干货 2016-07-16
  • Linux 根文件系统层级结构

    一、Linux根文件系统层级结构图 二、Linux根文件系统目录说明

    Linux干货 2016-09-26
  • Linux文本处理三剑客之awk详解

    前言 awk是一款强大的报告生成器,不同于sed和grep,它的侧重点是如何把文本信息更好的展示出来,常用与统计和格式化输出。awk相当于微型的shell,有着自己一套语法结构,例如:循环结构,数组,条件判断,函数,内置变量等功能。处理对象一般纯文本文件或纯文本信息。 用法详解 基本语法 awk [options] 'progra…

    Linux干货 2015-04-29
  • 操作系统文件管理

      在现代计算机系统中,要用到大量的程序和数据,因内存容量有限,且不能长期保存,故而平时总是把它们以文件的形式存放在外存中,需要时再随时将它们调入内存。如果由用户直接管理外存上的文件,不仅要求用户熟悉外存特性,了解各种文件的属性,以及它们在外存上的位置,而且在多用户环境下,还必须能保持数据的安全性和一致性。显然,这是用户所不能胜任、也不愿…

    Linux干货 2015-04-13
  • Linux进程管理命令和性能监控工具的应用

    概述 监控系统的各方面的性能,保障各类服务的有序运行,是运维工作的重要组成部分,本篇就介绍了一些常用的系统监控命令和相关参数的说明 具体包含一下几个部分 1.进程管理基础 2.进程管理工具(ps,top,htop,kill) 3.内存监控类工具(vmstat,pmap) 4.系统监控累工具(glances,dstat)…

    Linux干货 2016-09-26
  • linux下的文件查找命令对比(locate,find,grep,sed)

        在linux下,文件系统占据着非常重要的位置,而我们对于文件系统的操作也显得尤为重要。 如果我们想熟悉的操作文件系统,其中,我们需要对文本的查找,截取等命令需要熟悉的掌握。 这里就不得不说几个关于文本操作的几个命令的作用详细介绍和对比。比如: locate,find ,grep ,sed等。 这里,grep ,…

    Linux干货 2016-08-15