ConfigParser模块主要是用来解析配置文件的模块,像mysql,或者win下面的ini文件等等

下面我们来解析mysql的配置文件my.cnf

my.cnf配置文件内容

[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
user=mysql
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0

[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

SafeConfigParser()  是配置文件解析器类,该类的方法有

read(configfile):读取配置文件

get(node,options),找出node节点的options选项的值([mysqld]是节点,socket是选项)

[root@localhost config]# cat 1c.py 
import ConfigParser
parser=ConfigParser.SafeConfigParser()
parser.read('/etc/my.cnf')
print parser.get('mysqld','socket')
[root@localhost config]# python 1c.py 
/var/lib/mysql/mysql.sock

sections():获取配置文件的节点,返回一个列表

options(node):获取节点里面的选项,返回一个列表

items(node):把节点名里面选项和值,以字典的方式返回,即选项=值

1 [root@localhost config]# cat 2c.py 
 2 import ConfigParser
 3 parser=ConfigParser.SafeConfigParser()
 4 parser.read('/etc/my.cnf')
 5 print parser.sections()  #打印配置文件里面的节点
 6 for nodename in parser.sections():
 7     print "nodename:",nodename
 8     print "optionsname:",parser.options(nodename) #获取节点名里面的选项
 9     for name,value in parser.items(nodename):    #以字典的方式返回
10         print "%s=%s"%(name,value)
11 
12 [root@localhost config]# python 2c.py 
13 ['mysqld_safe', 'mysqld']
14 nodename: mysqld_safe
15 optionsname: ['log-error', 'pid-file']
16 log-error=/var/log/mysqld.log
17 pid-file=/var/run/mysqld/mysqld.pid
18 nodename: mysqld
19 optionsname: ['datadir', 'socket', 'symbolic-links', 'user']
20 datadir=/var/lib/mysql
21 socket=/var/lib/mysql/mysql.sock
22 symbolic-links=0
23 user=mysql

值的类型

get(node,options):会返回一个字符串

getint():返回一个整数

getfloat():返回一个浮点型

getboolean():返回布尔值,真值:1,yes,on,True 假值:0,no,off,false

如果mysql配置文件里面打开了log-bin日志功能那么里面的log-bin将是没有值的,这样在python2.6.6里面就没法解析文件

原因是这个python版本的ConfigParser.py文件缺少了allow_no_value属性,这个属性的值默认是False的

我想了一个偏门的方法,找一个python2.7.5的安装包把里面的ConfigParser.py文件复制到脚本运行的目录里面去,就样就可以运行了

[root@localhost config]# cat 3c.py 
import ConfigParser
parser=ConfigParser.SafeConfigParser(allow_no_value=True)
parser.read('/etc/my.cnf')
for node in parser.sections():
    for optionname in parser.options(node):
        print "%s=%s"%(optionname,parser.get(node,optionname)) #利用get方法返回一个值的整型,但是log-bin没有值,所以返回None
[root@localhost config]# python 3c.py 
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
user=mysql
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
symbolic-links=0
log-bin=None

测试节点或者选项是否存在

has_section(node):如果节点存在就返回True,不存在就返回False

has_option(node,option):如果节点里面的选项存在就返回True,不存在就返回False

这里我们来做个测试,还是上面那个my.cnf文件,我在[mysqld]里面添加了serverid这个选项但是没有给值,我没配置[mysqld1]这个节点和里面的serverid选项

1 [root@localhost config]# cat 4c.py 
 2 import ConfigParser
 3 parser=ConfigParser.SafeConfigParser(allow_no_value=True)
 4 parser.read('/etc/my.cnf')
 5 for section in ['mysqld','mysqld1']:
 6     print "[%s] is exists?:%s" %(section,parser.has_section(section))
 7     print "[%s]serverid option is exists?:%s"%(section,parser.has_option(section,'serverid'))
 8 [root@localhost config]# python 4c.py 
 9 [mysqld] is exists?:True
10 [mysqld]serverid option is exists?:True
11 [mysqld1] is exists?:False
12 [mysqld1]serverid option is exists?:Fals

add_section(node):增加一个节点

set(node,options,value):修改或者添加选项,注意值只接受字符串

remove_section(node):移除一个节点,注意节点移除后,这个节点里面的选项也会自动跟着移除

remove_option(node,option):移除一个选项

尝试添加一个mysqld1节点并添加选项和值serverid=2,和一个单独的选项log-bin,记住添加单独的属性值allow_no_value=True

(不知道为什么把节点给弄反了,一直没找出原因和解决方法)

1 [root@localhost config]# cat 5c.py
 2 import ConfigParser
 3 import sys
 4 parser=ConfigParser.SafeConfigParser(allow_no_value=True)
 5 parser.read('/etc/my.cnf')
 6 parser.add_section('mysqld1')
 7 parser.set('mysqld1','serverid','2')
 8 parser.set('mysqld1','log-bin')
 9 parser.write(sys.stdout)
10 [root@localhost config]# python 5c.py 
11 [mysqld1]
12 serverid = 2
13 log-bin
14 
15 [mysqld_safe]
16 log-error = /var/log/mysqld.log
17 
18 [mysqld]
19 socket = /var/lib/mysql/mysql.sock
20 datadir = /var/lib/mysql
21 log-bin
22 serverid = 2
23 symbolic-links = 0
24 user = mysql

修改serverid属性值并写进my.cnf文件(节点顺序也反了)

1 [root@localhost config]# cat 5c1.py 
 2 import ConfigParser
 3 parser=ConfigParser.SafeConfigParser(allow_no_value=True)
 4 parser.read('/etc/my.cnf')
 5 parser.set('mysqld','serverid','8')
 6 with open('/etc/my.cnf','w') as f:
 7     parser.write(f)
 8 [root@localhost config]# python 5c1.py 
 9 [root@localhost config]# cat 5c1.py 
10 import ConfigParser
11 parser=ConfigParser.SafeConfigParser(allow_no_value=True)
12 parser.read('/etc/my.cnf')
13 parser.set('mysqld','serverid','8')
14 with open('/etc/my.cnf','w') as f:
15     parser.write(f)
16 [root@localhost config]# cat /etc/my.cnf 
17 [mysqld_safe]
18 log-error = /var/log/mysqld.log
19 
20 [mysqld]
21 socket = /var/lib/mysql/mysql.sock
22 datadir = /var/lib/mysql
23 log-bin
24 serverid = 8
25 symbolic-links = 0
26 user = mysql