龙空技术网

Python 中使用 configparser 解析配置文件

口曷口曷口曷 85

前言:

此时咱们对“python解析配置文件”大概比较注意,朋友们都想要了解一些“python解析配置文件”的相关文章。那么小编在网上汇集了一些关于“python解析配置文件””的相关知识,希望咱们能喜欢,我们一起来了解一下吧!

如果你的 Python 项目需要切换多种配置方案,用 configparser 模块来管理会非常方便,网上 configparser 的教程都是2.x版本的,所以自己总结了一篇。

configparser 简介

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

配置文件的格式如下:

[DEFAULT]ServerAliveInterval = 45Compression = yesCompressionLevel = 9ForwardX11 = yes[bitbucket.org]User = Tom[topsecret.com]Port: 50022ForwardX11: no

“[ ]”包含的为 section,section 下面为类似于 key - value 的配置内容;

configparser 默认支持 ‘=’ ‘:’ 两种分隔。

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'}... })

获取所有 sections

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

获取指定 section 的 keys & values

>>> config.items('topsecret.com')>>>> [('port', '50022'), ('forwardx11', 'no')]    # 注意item()会使字符串全变成小写

获取指定 section 的 keys

>>> config.options('topsecret.com')['Port', 'ForwardX11']>>> for option in config['topsecret.com']:...     print(option)PortForwardX11

获取指定 key 的 value

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

检查

>>> 'DEFAULT' in configTrue>>> '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'))    # 一定要写入才生效

删除

>>> 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] 也无效:

>>> config.remove_section('DEFAULT')False>>> config.clear()>>> 'DEFAULT' in configTrue>>> '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 configTrue 

标签: #python解析配置文件