Python 中的配置文件解析器 (configparser)

pythonprogrammingserver side programming

Python 标准库中的 configparser 模块定义了读取和写入 Microsoft Windows 操作系统使用的配置文件的功能。此类文件通常具有 .INI 扩展名。

INI 文件由多个部分组成,每个部分都由 [section] 标题引导。在方括号之间,我们可以放置部分的名称。部分后面是用 = 或 : 字符分隔的键/值条目。它可能包含注释,前缀为 # 或 ; 符号。示例 INI 文件如下所示 −

[Settings]
# 设置详细日志以获取其他调试信息
DetailedLog=1
RunStatus=1
StatusPort=6090
StatusRefresh=10
Archive=1
# 设置 MV_FTP 日志文件的位置
LogFile=/opt/ecs/mvuser/MV_IPTel/log/MV_IPTel.log
Version=0.9 Build 4
ServerName=Unknown

[FTP]
# 设置 FTP 服务器处于活动状态
RunFTP=1
# 定义 FTP 控制端口
FTPPort=21
# 设置 FTP 数据目录的位置
FTPDir=/opt/ecs/mvuser/MV_IPTel/data/FTPdata
# 设置管理员名称
UserName=admin
# 设置密码
Password=admin

configparser 模块包含 ConfigParser 类。它负责解析配置文件列表,并管理解析后的数据库。

ConfigParser 的对象通过以下语句创建 −

parser = configparser.ConfigParser()

此类中定义了以下方法 −

sections()返回所有配置部分名称。
has_section()返回给定部分是否存在。
has_option()返回给定选项是否存在于给定部分中。
options()返回命名的配置选项列表部分。
read()读取并解析命名的配置文件。
read_file()读取并解析一个配置文件,以文件对象的形式给出。
read_string()从给定的字符串读取配置。
read_dict()从字典中读取配置。键是部分名称,值是具有该部分中应存在的键和值的字典。
get()返回命名选项的字符串值。
getint()类似于 get(),但将值转换为整数。
getfloat()类似于 get(),但将值转换为浮点数。
getboolean()类似于 get(),但将值转换为布尔值。返回 False 或 True。
items()返回该部分中每个选项的 (name, value) 元组列表。
remove_section()删除给定的文件部分及其所有选项。
remove_option()从给定部分中删除给定选项。
set()设置给定选项。
write()以 .ini 格式写入配置状态。

以下脚本读取并解析 'sampleconfig.ini' 文件

import configparser
parser = configparser.ConfigParser()
parser.read('sampleconfig.ini')
for sect in parser.sections():
   print('Section:', sect)
   for k,v in parser.items(sect):
      print(' {} = {}'.format(k,v))
   print()

输出

Section: Settings
detailedlog = 1
runstatus = 1
statusport = 6090
statusrefresh = 10
archive = 1
logfile = /opt/ecs/mvuser/MV_IPTel/log/MV_IPTel.log
version = 0.9 Build 4
servername = Unknown

Section: FTP
runftp = 1
ftpport = 21
ftpdir = /opt/ecs/mvuser/MV_IPTel/data/FTPdata
username = admin
password = admin

write() 方法用于创建配置文件。以下脚本配置解析器对象并将其写入代表"test.ini"的文件对象

import configparser
parser = configparser.ConfigParser()
parser.add_section('Manager')
parser.set('Manager', 'Name', 'Ashok Kulkarni')
parser.set('Manager', 'email', 'ashok@gmail.com')
parser.set('Manager', 'password', 'secret')
fp=open('test.ini','w')
parser.write(fp)
fp.close()

相关文章