python中configparser函数_Python3 中 configparser 模块解析配置的用法详解

configparser 简介

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

配置文件的格式如下:

[DEFAULT]

ServerAliveInterval = 45

Compression = yes

CompressionLevel = 9

ForwardX11 = yes

[bitbucket.org]

User = Tom

[topsecret.com]

Port: 50022

ForwardX11: 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')] # 注意items()返回的字符串会全变成小写

获取指定 section 的 keys

>>> config.options('topsecret.com')

['Port', 'ForwardX11']

>>> for option in config['topsecret.com']:

... print(option)

Port

ForwardX11

获取指定 key 的 value

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

删除

>>> 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 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

微信公众号

新开了微信公众号:面向人生编程

编程思维不应只存留在代码之中,更应伴随于整个人生旅途,所以公众号里不只聊技术,还会聊产品/互联网/经济学等广泛话题,所以也欢迎非程序员关注。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值