python ConfigParser模块 配置文件解析

时间:2022-09-08 11:26:04

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