以下代码以Python3.6.1为例
Less is more!
configparser可以读写和解析注释文件, 但是没有写入注释的功能
1#!/usr/bin/env python
2# coding=utf-8
3__author__ = 'Luzhuo'
4__date__ = '2017/5/26'
5# config_configparser.py配置文件
6# configparser可以读写和解析注释文件, 但是没有写入注释的功能
7
8importconfigparser
9importre
10
11
12config_str = '''
13#配置文件信息案例
14[DEFAULT]
15minSdkVersion = 15
16targetSdkVersion = 24
17versionName = 1.0.0
18server action = yes
19
20[luzhuo.me]
21user = luzhuo
22
23# This is a comments.
24[mysql]
25ip = 127.0.0.1
26port = 3306
27'''
28
29defconfig_write():
30'''
31生成配置文件, 字典的形式添加数据
32'''
33
34config =configparser.ConfigParser()
35
36config['DEFAULT'] = {'minSdkVersion': '15',
37'targetSdkVersion': '24',
38'versionName': '1.0.0',
39'server action': 'yes'}
40
41config['luzhuo.me'] ={}
42config['luzhuo.me']['user'] = 'luzhuo'
43
44config['mysql'] ={}
45topsecret = config['mysql']
46topsecret['ip'] = '127.0.0.1'
47topsecret['port'] = '3306'
48
49with open('config.ini', 'w') as configfile:
50config.write(configfile)
51
52
53defconfig_read():
54'''
55解析配置文件
56'''
57
58#读取
59config =configparser.ConfigParser()
60config.read('config.ini')
61
62lists_header = config.sections() #配置组名, ['luzhuo.me', 'mysql'] # 不含'DEFAULT'
63print(lists_header)
64
65boolean = 'luzhuo.me' in config #配置组是否存在
66boolean = config.has_section("luzhuo.me")
67print(boolean)
68
69user = config['luzhuo.me']['user']
70print(user)
71mysql = config['mysql']
72mysql_ip = mysql['ip']
73mysql_port = mysql['port']
74print(mysql_ip, ":", mysql_port)
75
76for key in config['luzhuo.me']: #遍历配置组的key, 与'DEFAULT'组的key
77print(key)
78
79#删除
80sec = config.remove_section("luzhuo.me") #删除
81config.write(open("config.ini", "w")) #写回去
82
83#添加
84config.add_section("web.server")
85config.write(open("config.ini", "w"))
86
87#修改/添加
88config.set("web.server", "http", "http://luzhuo.me")
89config.write(open("config.ini", "w"))
90
91#删除key
92config.remove_option("mysql", "ip")
93config.write(open("config.ini", "w"))
94
95
96defconfig_func():
97'''
98写入的值均为字符串
99配合文件的节名称区分大小写, 键不区分大小写(可任意缩进), 注释用'#'和';'(用作整行前缀,可缩进,不推荐行内注释), 值可以跨越多行(要缩进,慎用), 键值分隔符'='和':'
100DEFAULT无法移除,试图删除将引发ValueError, clear()保持原样, popitem()不返回
101'''
102
103# --- ConfigParser对象---
104#配置解析器, defaults:DEFAULT字典, dict_type:字典类型(默认:有序字典), allow_no_value:True是否接收不带值的选项(值为None),(默认False), delimiters:键值分隔符, comment_prefixes:整行注释符, inline_comment_prefixes:行内注释符(值之后), strict:是否去重:True(默认), empty_lines_in_values:值是否可以多行;(默认True),False(行标记选项的结尾), default_section:默认节的名称'DEFAULT', interpolation:插值, converters:转换器{类型转换器的名称, 从字符串转换所需数据的类型}{'dicimal': decimal.Decimal}
105# class configparser.ConfigParser(defaults=None, dict_type=collections.OrderedDict, allow_no_value=False, delimiters=('=', ':'), comment_prefixes=('#', ';'), inline_comment_prefixes=None, strict=True, empty_lines_in_values=True, default_section=configparser.DEFAULTSECT, interpolation=BasicInterpolation(), converters={})
106config =configparser.ConfigParser()
107
108# items(raw=False, vars=None) #所有节(含DEFAULT) ItemsView(section_name, section_proxy)(可遍历对象)
109ItemsView =config.items()
110dicts = config.defaults() # DEFAULT字典
111lists = config.sections() #可用的节列表(不含DEFAULT)
112# has_section(section) #是否存在该节
113boolean = config.has_section("mysql")
114lists = config.options("mysql") #指定节的选项列表(含DEFAULT)
115boolean = config.has_option("mysql", "ip") #是否存在指定节的选项
116
117# read(filenames, encoding=None) #尝试读取和解析文件名列表(不存在则忽略), 加载初始值调用read_file()要在read()之前调用
118config.read("config.ini", encoding="utf-8-sig") # windows下用记事本保存utf8格式要用utf-8-sig编码集
119# read_file(f, source=None) #从f读取和解析配置数据, source:文件名
120config.read_file(open('config.ini', encoding="utf-8-sig"))
121# read_string(string, source='') #从字符串解析配置数据
122config.read_string(config_str)
123# read_dict(dictionary, source='') #读取字典
124config.read_dict({'section1': {'key1': 'value1',
125'key2': 'value2'},
126'section2': {'key3': 'value3',
127'key4': 'value4'}
128})
129
130# get(section, option, *, raw=False, vars=None[, fallback]) #获取指定节的选项值, fallback:为找到选项时的返回值
131data_str = config.get("mysql", "ip", fallback=None)
132# getint(section, option, *, raw=False, vars=None[, fallback]) #获取整数(选项的值强转为整数)
133data_int = config.getint("mysql", "port", fallback=-1)
134# getfloat(section, option, *, raw=False, vars=None[, fallback])
135data = float = config.getfloat("mysql", "port", fallback=-1)
136# getboolean(section, option, *, raw=False, vars=None[, fallback])
137data_bool = config.getboolean("DEFAULT", "server action", fallback=False) #获取布尔值,不区分大小写,识别'yes'/'no','on'/'off','true'/'false','1'/'0'
138
139# write(fileobject, space_around_delimiters=True) #将配置写入文件, space_around_delimiters:是否用空格分隔键值之间
140config.write(open("config.ini", "w", encoding="utf-8"))
141# add_section(section) #添加节, 节重复DuplicateSectionError, 与默认节重复ValueError, 不是字符串TypeError
142config.add_section("server.luzhuo.me")
143# remove_section(section) #删除节, 存在True,不存在False
144boolean = config.remove_section("server.luzhuo.me")
145# set(section, option, value) #给指定的节设置值, 节不存在NoSectionError, option和value:选项和值为字符串,否则TypeError
146config.set("server.luzhuo.me", "ip", "127.0.0.1")
147# remove_option(section, option) #删除选型, 不存在节NoSectionError,选项存在True,不存在False
148boolean = config.remove_option("server.luzhuo.me", "ip")
149
150# optionxform(option) #子类重写该方法, 或config.optionxform = str(str区分大小写) 修改, 用于选项名称转为在内部结构中使用的实现
151
152configparser.MAX_INTERPOLATION_DEPTH #使用默认插值时, 当raw=false,get()递归插值的最大深度
153
154config.clear() #所有节都包含'DEFAULT'值,对节的清空不会删除'DEFAULT'值
155config.BOOLEAN_STATES.update({'enabled': True, 'disabled': False}) #自定义boolean的判断
156config.SECTCRE = re.compile(r"\[ *(?P[^]]+?) *\]") #自定义节头的编译与解析的正则表达式(去除左右空格)
157
158
159
160# ---异常 ---
161try: pass
162except configparser.Error: pass # configparser异常的基类
163except configparser.NoSectionError: pass #未找到指定节
164except configparser.DuplicateSectionError: pass #节重复
165except configparser.DuplicateOptionError: pass #选项重复
166except configparser.NoOptionError: pass #未找到指定选项
167except configparser.InterpolationError: pass #插值异常的基类
168except configparser.InterpolationDepthError: pass #迭代次数超过MAX_INTERPOLATION_DEPTH
169except configparser.InterpolationMissingOptionError: pass #选项不存在
170except configparser.InterpolationSyntaxError: pass #替换源文本不符合语法
171except configparser.MissingSectionHeaderError: pass #没有节头
172except configparser.ParsingError: pass #解析文件错误
173
174
175
176if __name__ == "__main__":
177config_write()
178config_read()
179
180# config_func()