Python3 中 configparser 模块解析配置的用法详解

configparser 简介

configparser 是 Pyhton 标准库中用来解析配置文件的模块,而且内置方法和字典很是接近。Python2.x 中名为 ConfigParser,3.x 已改名小写,并加入了一些新功能。 配置文件的格式以下:html

[DEFAULT]
ServerAliveInterval = 45
Compression = yes
CompressionLevel = 9
ForwardX11 = yes

[bitbucket.org]
User = Tom

[topsecret.com]
Port: 50022
ForwardX11: no
复制代码

“[ ]”包含的为 section,section 下面为相似于 key - value 的配置内容; configparser 默认支持 '=' ':' 两种分隔。python


###configparser 经常使用方法 ####初始化实例 使用 configparser 首先须要初始化实例,并读取配置文件:程序员

>>> import configparser
>>> config = configparser.ConfigParser()	# 注意大小写
>>> config.read("config.ini")	# 配置文件的路径
["config.ini"]
复制代码

或者能够直接读字典编程

>>> parser = configparser.ConfigParser()
>>> parser.read_dict({'section1': {'key1': 'value1',
...                                'key2': 'value2',
...                                'key3': 'value3'},
...                   'section2': {'keyA': 'valueA',
...                                'keyB': 'valueB',
...                                'keyC': 'valueC'},
...                   'section3': {'foo': 'x',
...                                'bar': 'y',
...                                'baz': 'z'}
... })
复制代码

####获取全部 sectionsbash

>>> config.sections()
['bitbucket.org', 'topsecret.com']    # 注意会过滤掉[DEFAULT]
复制代码

####获取指定 section 的 keys & values微信

>>> config.items('topsecret.com')
>>>> [('port', '50022'), ('forwardx11', 'no')]    # 注意items()返回的字符串会全变成小写
复制代码

####获取指定 section 的 keysui

>>> config.options('topsecret.com')
['Port', 'ForwardX11']
复制代码
>>> for option in config['topsecret.com']:
...	    print(option)
Port
ForwardX11
复制代码

####获取指定 key 的 valuespa

>>> config['bitbucket.org']['User']
'Tom'
复制代码
>>> config.get('bitbucket.org', 'User')
'Tom'
>>> config.getint('topsecret.com', 'Port')
50022
复制代码

检查

>>> 'DEFAULT' in config
True
>>> 'test' in config['section_test']
False
>>> 'Tom' in config['bitbucket.org']['User']
True
复制代码
>>> config.has_section('bitbucket.org')
True
>>> config.has_option('section_test', 'test')
False
复制代码

添加

>>> config.add_section('Section_1')
>>> config.set('Section_1', 'key_1', 'value_1')    # 注意键值是用set()方法
>>> config.write(open('config.ini', 'w'))    # 必定要写入才生效
复制代码

####删除code

>>> config.remove_option('Section_1', 'key_1')
True
>>> config.remove_section('Section_1')
True
>>> config.clear()	# 清空除[DEFAULT]以外全部内容
>>> config.write(open('config.ini', 'w'))
复制代码

###关于 [DEFAULT] [DEFAULT] 通常包含 ini 格式配置文件的默认项,因此 configparser 部分方法会自动跳过这个 section 。 前面已经提到 sections() 是获取不到的,还有删除方法对 [DEFAULT] 也无效:cdn

>>> config.remove_section('DEFAULT')
False
>>> config.clear()
>>> 'DEFAULT' in config
True
>>> 'ForwardX11' in config['DEFAULT']
True
>>> config.sections()
[]
复制代码

但指定删除和修改 [DEFAULT] 里的 keys & values 是能够的:

>>> config.remove_option('DEFAULT', 'ForwardX11')
True
>>> config.set('DEFAULT', 'ForwardX11','no')
>>> config['DEFAULT']['ForwardX11']
'no'
复制代码

还有个特殊的是,has_section() 也无效,能够和 in 区别使用

>>> config.has_section('DEFAULT')
False
>>> 'DEFAULT' in config
True
复制代码

更多用法请看官方文档: docs.python.org/3.6/library…


微信公众号

新开了微信公众号:面向人生编程 编程思惟不该只存留在代码之中,更应伴随于整我的生旅途,因此公众号里不仅聊技术,还会聊产品/互联网/经济学等普遍话题,因此也欢迎非程序员关注。
相关文章
相关标签/搜索