Python3.6安装ConfigPar
本文转载至:http://www.pythontab.com/html/2014/pythonhexinbiancheng_1120/919.html
1.基本的读取配置文件
-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() 函数。
2.基本的写入配置文件
-add_section(section) 添加一个新的section
-set( section, option, value) 对section中的option进行设置,需要调用write将内容写入配置文件。
3.基本例子
test.conf
1
2
3
4
5
6
7
8
9
|
[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 |
parse_test_conf.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
import ConfigParser cf = ConfigParser.ConfigParser() #read config cf.read( "test.conf" ) # return all section 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 #write config #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" )) |
得到终端输出:
1
2
3
4
5
|
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
1
2
3
4
5
6
7
8
9
10
11
12
13
|
[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 |
4.Python的ConfigParser Module中定义了3个类对INI文件进行操作。分别是RawConfigParser、ConfigParser、SafeConfigParser。RawCnfigParser是最基础的INI文件读取类,ConfigParser、SafeConfigParser支持对%(value)s变量的解析。
设定配置文件test2.conf
1
2
3
4
|
[portal] url = http: // %(host)s:%(port)s /Portal host = localhost port = 8080 |
使用RawConfigParser:
1
2
3
4
5
6
7
8
9
10
11
|
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" ) |
得到终端输出:
1
2
3
4
|
use RawConfigParser() read http: // %(host)s:%(port)s /Portal use RawConfigParser() write %(host)s:%(port)s |
改用ConfigParser:
1
2
3
4
5
6
7
8
9
10
11
|
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" ) |
得到终端输出:
1
2
3
4
|
use ConfigParser() read http: //localhost :8080 /Portal use ConfigParser() write localhost:8080 |
改用SafeConfigParser:
1
2
3
4
5
6
7
8
9
10
11
|
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):
1
2
3
4
|
use SafeConfigParser() read http: //localhost :8080 /Portal use SateConfigParser() write localhost:8080 |
Python3.6 安装ConfigParse 模块
开发环境:windows10、Python3.5、DJango1.11.1
第一步:首先,下载对应configparse的 .whl文件,下载地址:http://www.lfd.uci.edu/~gohlke/pythonlibs/#simplejson
第二步:打开cmd,进入到Python安装目录的Scripts文件夹中.比如:D:\Program Files\Python\Scripts。使用pip安装刚刚下载好的whl文件,pip.exe install *.whl,例如:
D:\Program Files\python\Scripts>pip.exe install D:\python\configparser-3.5.0-py2.py3-none-any.whl
Processing d:\python\configparser-3.5.0-py2.py3-none-any.whl
Installing collected packages: configparser
Successfully installed configparser-3.5.0
提示安装成功后,在\Python\Lib\site-packages目录下可以看到configparse.
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341