Python configparser 模块

目录

1、配置文件的格式如下:

2、configparser 常用方法

3、关于 [DEFAULT]注意事项


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

1、配置文件的格式如下:

[DEFAULT]
ServerAliveInterval = 45
Compression = yes
CompressionLevel = 9
ForwardX11 = yes

[bitbucket.org]
User = Tom

[topsecret.com]
Port: 50022
ForwardX11: no

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

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

2、configparser 常用方法

# encoding: utf-8

"""
@author: sunxianpeng
@file: configparser_test.py
@time: 2019/12/1 20:34
"""
import configparser

def get_config(type='ini'):
    """读取文件形式或者字典形式获取configparser的实例类config"""
    config = configparser.ConfigParser()
    if type == 'ini':
        config.read(config_path)
    if type == 'dict':
        config.read_dict({'section1': {'key1': 'value1','key2': 'value2','key3': 'value3'},
                          'section2': {'keyA': 'valueA','keyB': 'valueB',  'keyC': 'valueC'},
                          'section3': {'foo': 'x', 'bar': 'y','baz': 'z'}})
    return config

def foreach_config(config):
    print("######################查找配置文件中的信息###########################")
    # 1、获取所有 sections
    sections = config.sections()# # 注意会过滤掉[DEFAULT]
    i = 0
    for section in sections:
        print('第 {} 个主题= {}下的配置'.format(i,section))

        print("**********1、获取指定 section 的 keys & values*******")
        items = config.items(section)
        for tup_kv in items:
            print('主题 = {} 下的 第一个键值对为 = {}'.format(section,tup_kv))#('serveraliveinterval', '45')
            break

        print("**********2、获取指定 section 的 keys*******")
        keys = config.options(section)
        for key in keys:
            print('主题 = {} 下的 第一个键为 = {}'.format(section,key))
            break

        print("**********3、获取指定 key 的 value*******")
        value_1 = config[section]['user']
        value_2 = config.get(section,'user')#Tom
        print('主题 = {} 下,key 为 user 的 值 = {}'.format(section,value_1))

        # 获取指定 key 的 value
        i += 1
        break

def check_add_delete_config_info(config):
    """检查、添加、删除配置文件中的信息"""
    print("#####################检查、添加、删除配置文件中的信息#########################")
    print("**********1、检查是否在配置文件中*********")
    section_check_1 = 'DEFAULT' in config
    section_check_2 = config.has_section('DEFAULT')
    key_check_1 = 'test' in config['DEFAULT']
    key_check_2 = config.has_option('section_test', 'test')
    value_check = 'Tom' in config['bitbucket.org']['User']
    print("check section default = {}".format(section_check_1))
    print("check key test of DEFAULT = {}".format(key_check_2))
    print("check value Tom of bitbucket.org = {}".format(value_check))

    print("**********2、向配置文件中添加配置*********")
    config.add_section('Section_1')
    config.set('Section_1', 'key_1', 'value_1')  # 注意键值是用set()方法
    config.write(open('configparser.ini', 'w'))  # 一定要写入才生效

    print("**********3、删除配置文件中的内容********")
    config.remove_option('Section_1', 'key_1')
    config.remove_section('Section_1')
    # config.clear()  # 清空除[DEFAULT]之外所有内容
    config.write(open('configparser.ini', 'w'))



if __name__ == '__main__':
    config_path = 'configparser.ini'# 配置文件的路径
    config = get_config(type='ini')
    foreach_config(config)
    check_add_delete_config_info(config)

3、关于 [DEFAULT]注意事项

  • [DEFAULT] 一般包含 ini 格式配置文件的默认项,所以 configparser 部分方法会自动跳过这个 section 。

  • 前面已经提到 sections() 是获取不到的,还有删除方法对 [DEFAULT] 也无效

  • 指定删除和修改 [DEFAULT] 里的 keys & values 是可以的

  • has_section()对于检查 DEFAULT 无效,对其他有效,可以和 in 区别使用

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值