脚本专栏 
首页 > 脚本专栏 > 浏览文章

Python3中configparser模块读写ini文件并解析配置的用法详解

(编辑:jimmy 日期: 2025/1/16 浏览:3 次 )

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

configparser模块检查

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

configparser模块添加

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

configparser模块删除

> 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

更多关于Python3中configparser模块读写ini文件并解析配置的用法请查看下面的相关链接

上一篇:tensorflow 分类损失函数使用小记
下一篇:python如何把字符串类型list转换成list
一句话新闻
高通与谷歌联手!首款骁龙PC优化Chrome浏览器发布
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 站点导航 SiteMap