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