使用ConfigParser模块读写ini文件
ConfigParserPython的ConfigParser Module中定义了3个类对INI文件进行操作。分别是RawConfigParser、ConfigParser、SafeConfigParser。模块所解析的ini配置文件是由多个section构成,每个section名用中括号‘[]’包含,每个section下可有多个配置项类似于key-value形式,例如:
[Server]
SvrInfo = test
Version = 1.1
[Client]
Version = 1.0
ConfigParser模块以ConfigParser类为例,其操作基本分为三类:1)初始化;2)读取配置;3)写入配置。
1. ConfigParser 初始化
使用ConfigParser 首选需要初始化实例,并读取配置文件:
cf = ConfigParser.ConfigParser() cf.read("配置文件名")
2. 基本的读取配置文件
-read(filename) 直接读取ini文件内容
-sections() 得到所有的section,并以列表的形式返回
-options(section) 得到该section的所有option
-items(section) 得到该section的所有键值对
-get(section,option) 得到section中option的值,返回为string类型
-getint(section,option) 得到section中option的值,返回为int类型,还有相应的getboolean()和getfloat() 函数。
3.基本的写入配置文件
-add_section(section) 添加一个新的section
-set( section, option, value) 对section中的option进行设置,需要调用write将内容写入配置文件。
-write(strout) 将对configparser类的修改写入
例如:
test.conf [sec_a] a_key1 = 20 a_key2 = 10 [sec_b] b_key1 = 121 b_key2 = b_value2 b_key3 = $r b_key4 = 127.0.0.1 import ConfigParser #初始化 cf = ConfigParser.ConfigParser() cf.read("test.conf") # 读取配置文件 secs = cf.sections() print 'sections:', secs opts = cf.options("sec_a") print 'options:', opts kvs = cf.items("sec_a") print 'sec_a:', kvs #read by type str_val = cf.get("sec_a", "a_key1") int_val = cf.getint("sec_a", "a_key2") print "value for sec_a's a_key1:", str_val print "value for sec_a's a_key2:", int_val #写入配置文件 #update value cf.set("sec_b", "b_key3", "new-$r") #set a new value cf.set("sec_b", "b_newkey", "new-value") #create a new section cf.add_section('a_new_section') cf.set('a_new_section', 'new_key', 'new_value') #write back to configure file cf.write(open("test.conf", "w")) 得到终端输出: sections: ['sec_b', 'sec_a'] options: ['a_key1', 'a_key2'] sec_a: [('a_key1', "i'm value"), ('a_key2', '22')] value for sec_a's a_key1: i'm value value for sec_a's a_key2: 22 更新后的test.conf [sec_b] b_newkey = new-value b_key4 = 127.0.0.1 b_key1 = 121 b_key2 = b_value2 b_key3 = new-$r [sec_a] a_key1 = i'm value a_key2 = 22 [a_new_section] new_key = new_value
Python的ConfigParser Module定义的3个类中,RawCnfigParser是最基础的INI文件读取类,ConfigParser、SafeConfigParser支持对%(value)s变量的解析。
设定配置文件test2.conf [portal] url = http://%(host)s:%(port)s/Portal host = localhost port = 8080 使用RawConfigParser: import ConfigParser cf = ConfigParser.RawConfigParser() print "use RawConfigParser() read" cf.read("test2.conf") print cf.get("portal", "url") print "use RawConfigParser() write" cf.set("portal", "url2", "%(host)s:%(port)s") print cf.get("portal", "url2")
得到终端输出:
use RawConfigParser() read
http://%(host)s:%(port)s/Portal use RawConfigParser() write
%(host)s:%(port)s 改用ConfigParser: import ConfigParser cf = ConfigParser.ConfigParser() print "use ConfigParser() read" cf.read("test2.conf") print cf.get("portal", "url") print "use ConfigParser() write" cf.set("portal", "url2", "%(host)s:%(port)s") print cf.get("portal", "url2")
得到终端输出:
use ConfigParser() read
http://localhost:8080/Portal use ConfigParser() write
localhost:8080 改用SafeConfigParser: import ConfigParser cf = ConfigParser.SafeConfigParser() print "use SafeConfigParser() read" cf.read("test2.conf") print cf.get("portal", "url") print "use SateConfigParser() write" cf.set("portal", "url2", "%(host)s:%(port)s") print cf.get("portal", "url2")
得到终端输出(效果同ConfigParser):
use SafeConfigParser() read http://localhost:8080/Portal
use SateConfigParser() write
localhost:8080
另外,几种常见的异常:
Exception NoSectionError
当没有发现给定section时抛出。
Exception DuplicateSectionError
如果add_section()方法被调用时,提供的section参数的值已经存在时抛出。
Exception NoOptionError
指定option不存在时抛出。
Exception InterpolationError
执行字符串填补时抛出的异常的基类。
Exception InterpolationDepthError
当填补字符串因为迭代次数超过了MAX_INTERPOLATION_DEPTH值时抛出的异常,InterpolationError的子类。
Exception InterpolationMissingOptionError
当option引用的值不存在时抛出,该异常为InterpolationError的子类,2.3版本新加。
Exeption InterpolationSyntaxError
当原文件格式没有遵守规定的语法时抛出的异常,继承至InterpolationError,2.3版本。
Exception MissingSectionHeaderError
尝试解析没有section头的文件时抛出。
Exception ParsingError
解析文件时发生错误。
转自:http://houwenhui.gotoip2.com/archives/1132
转自:http://www.linuxso.com/linuxbiancheng/8987.html