使用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
解析文件時發生錯誤。