文章出處

Python 標準庫的 ConfigParser 模塊提供一套 API 來讀取和操作配置文件。

 

配置文件的格式

a) 配置文件中包含一個或多個 section, 每個 section 有自己的 option;

b) section 用 [sect_name] 表示,每個option是一個鍵值對,使用分隔符 =: 隔開;

c) 在 option 分隔符兩端的空格會被忽略掉

d) 配置文件使用 # 和 ; 注釋

一個簡單的配置文件樣例 myapp.conf

1
2
3
4
5
6
7
8
9
10
11
12
# database source
[db]
host = 127.0.0.1
port = 3306
user = root
pass = root
 
# ssh
[ssh]
host = 192.168.1.101
user = huey
pass = huey

 ConfigParser 的基本操作

a) 實例化 ConfigParser 并加載配置文件

1
2
cp = ConfigParser.SafeConfigParser()
cp.read('myapp.conf')

b) 獲取 section 列表、option 鍵列表和 option 鍵值元組列表 

1
2
3
print 'all sections:', cp.sections()        # sections: ['db', 'ssh']
print 'options of [db]:', cp.options('db'# options of [db]: ['host', 'port', 'user', 'pass']
print 'items of [ssh]:', cp.items('ssh')    # items of [ssh]: [('host', '192.168.1.101'), ('user', 'huey'), ('pass', 'huey')]

c) 讀取指定的配置信息

1
2
print 'host of db:', cp.get('db', 'host')     # host of db: 127.0.0.1
print 'host of ssh:', cp.get('ssh', 'host')   # host of ssh: 192.168.1.101

d) 按類型讀取配置信息:getint、 getfloat 和 getboolean

print type(cp.getint('db', 'port'))        # <type 'int'>

e) 判斷 option 是否存在

1
print cp.has_option('db', 'host')    # True  

f) 設置 option

1
cp.set('db', 'host','192.168.1.102')

g) 刪除 option

1
cp.remove_option('db', 'host')

h) 判斷 section 是否存在

print cp.has_section('db')    # True

i) 添加 section

cp.add_section('new_sect')

j) 刪除 section

cp.remove_section('db')

k) 保存配置,set、 remove_option、 add_section 和 remove_section 等操作并不會修改配置文件,write 方法可以將 ConfigParser 對象的配置寫到文件中

cp.write(open('myapp.conf', 'w'))
cp.write(sys.stdout)

Unicode 編碼的配置

配置文件如果包含 Unicode 編碼的數據,需要使用 codecs 模塊以合適的編碼打開配置文件。

myapp.conf

[msg]
hello = 你好

config_parser_unicode.py

復制代碼
復制代碼
import ConfigParser
import codecs

cp = ConfigParser.SafeConfigParser()
with codecs.open('myapp.conf', 'r', encoding='utf-8') as f:
    cp.readfp(f)

print cp.get('msg', 'hello')
復制代碼
復制代碼

 

allow_no_value

通常情況下, option 是一個鍵值對。但是,當 SafeConfigParser 的參數 allow_no_value 設置成 True 時,它允許 option 不設置值而只是作為一個標識。

allow_no_value.conf

# option as Flag
[flag]
flag_opt

allow_no_value.py

import ConfigParser

cp = ConfigParser.SafeConfigParser(allow_no_value = True)
cp.read('myapp.conf')
print cp.get('flag', 'flag_opt');    # None

allow_no_value 默認設置成 False,此時如果配置文件中存在沒有設置值的 option,在讀取配置文件時將拋出異常 ConfigParser.ParsingError。當 allow_no_value 設置成 True 時,如果一個 option 沒有設置值,has_option 方法會返回 True,get 方法會返回 None。

 

DEFAULT section

如果配置文件中存在一個名為 DEFAULT 的 section,那么其他 section 會擴展它的 option 并且可以覆蓋它的 option。

db.conf

復制代碼
復制代碼
[DEFAULT]
host = 127.0.0.1
port = 3306

[db_root]
user = root
pass = root

[db_huey]
host = 192.168.1.101
user = huey
pass = huey
復制代碼
復制代碼

default_section.py

print cp.get('db_root', 'host')    # 127.0.0.1
print cp.get('db_huey', 'host')    # 192.168.1.101

 

插值 Interpolation

SafeConfigParser 提供了插值的特性來結合數據。

url.conf

復制代碼
復制代碼
[DEFAULT]
url = %(protocol)s://%(server)s:%(port)s/

[http]
protocol = http
server = localhost
port = 8080

[ftp]
url = %(protocol)s://%(server)s/
protocol = ftp
server = 192.168.1.102
復制代碼
復制代碼

interpolation_demo.py

復制代碼
復制代碼
import ConfigParser

cp = ConfigParser.SafeConfigParser()
cp.read('url.conf')

print cp.get('http', 'url')    # http://localhost:8080/
print cp.get('ftp', 'url')     # ftp://192.168.1.102/
復制代碼

更多 ConfigParser 的使用,參考:

http://blog.csdn.net/zm2714/article/details/8002125

 


文章列表


不含病毒。www.avast.com
arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()