import os
from configparser import ConfigParser
# 读取ini配置文件函数
def fun_read_ini(file_name, section):
"""[summary]
Args:
file_name ([str]): [文件路径]
section ([str]): [读取字段]
Returns:
[dic]: [字典方式返回字段的配置内容]
"""
if os.path.isfile(file_name):
cfg = ConfigParser()
cfg.read(file_name, encoding='utf-8')
options = cfg.options(section)
dic_options = {option: cfg.get(section, option) for option in options}
return dic_options
else:
print('文件不存在')
def fun_write_ini(file_name, section, option, value):
"""[summary]
Args:
file_name ([str]): [文件路径]
section ([str]): [选择字段]
key ([str]): [选择要字的键]
Value ([str]): [要写的值]
Returns:
[dic]: [字典方式返回字段的配置内容]
"""
if os.path.isfile(file_name):
# 创建配置对象
cfg = ConfigParser()
# 先要读出来,放内存
cfg.read(file_name, encoding='utf-8')
# 做配置,写进内存
cfg.set(section,option,value)
# 写配置写入ini,用w是因为清空全部,把内存的东西全新写入
cfg.write(open(file_name,'w', encoding='utf-8'))
关于configparser
实例化
__init__(defaults=None, dict_type=_default_dict, allow_no_value=False,
delimiters=('=', ':'), comment_prefixes=('#', ';'),
inline_comment_prefixes=None, strict=True,
empty_lines_in_values=True, default_section='DEFAULT',
interpolation=<unset>, converters=<unset>)
从源码看出,这个ini文档,可以像字典一样,使用“:”,但一般我们都使用“=”,并且值都不需要加引号
备注可以使用'#'或';',单独一行,可缩进。
class ConfigParser(RawConfigParser):
class RawConfigParser(MutableMapping):
常规操作
详细看官网,不搬砖,列出几个我自己常用的
sections()
返回可用节的列表;default section 不包括在该列表中options(section)
返回指定 section 中可用选项的列表。-
read(filenames, encoding=None)
简单理解flienames可以是指定的某个配置文件,如果你这个目录有多个配置文件,你可以直接传一个目录进去,他能返回多个可迭代对象。
下面的这些用得不多,记得有这回事即可。
get(self, section, option, *, raw=False, vars=None, fallback=_UNSET)
获取指定名称的 section 的一个 option 的值。items(raw=False, vars=None)
items(section=_UNSET, raw=False, vars=None)
当未给出 section 时,将返回由 section_name, section_proxy 对组成的列表,包括 DEFAULTSECT。
在其他情况下,将返回给定的 section 中的 option 的 name, value 对组成的列表。remove_section(section)
将指定的 option 从指定的 section 中移除。 如果指定的节不存在则会引发 NoSectionError。 如果要移除的选项存在则返回 True;在其他情况下将返回 False。remove_option(section, option)
从配置中移除指定的 section。 如果指定的节确实存在则返回 True。 在其他情况下将返回 False。set(section, option, value)
如果给定的节存在,则将所给出的选项设为指定的值;在其他情况下将引发 NoSectionError。 option 和 value 必须为字符串;如果不是则将引发 TypeError。但这个仅在内存中,真正要写入ini还得用write()
write(fp, space_around_delimiters=True)
将配置的表示形式写入指定的 file object,该对象必须以文本模式打开(接受字符串)。 此表示形式可由将来的 read() 调用进行解析。 如果 space_around_delimiters 为真值,键和值之前的分隔符两边将加上空格。