Python configparsr标准库简介:轻松处理INI文件

如果你要使用Python处理类似ini这种格式的文件,那么肯定离不开configparser标准库,它使用起来很简单而且非常方便。下面就让我们来看看吧。

简单读写

读写ini文件非常简单,来看看下面的例子就明白了。首先要创建ConfigParser的实例,使用它则非常简单,基本上就和处理字典完全一样。处理完毕之后,调用ConfigParser的write方法并传递一个文件就可以将其保存下来了。读取时候更加简单,直接向read方法传递文件名即可。

<code>import configparser

config_filename = 'config.ini'

config = configparser.ConfigParser()
config['default'] = {'name': '易天', 'age': 30, 'gender': 'male'}
config['young'] = {'name': 'yitian', 'age': 20}

with open(config_filename, 'w', encoding='utf8')as file:
config.write(file)

config2 = configparser.ConfigParser()
config2.read(config_filename, encoding='utf8')
for section in config2.sections():
print(f'[{section}]')
for key in config2[section]:
print(f'{key} = {config2[section][key]}')

'''
[default]
name = 易天
age = 30
gender = male
[young]
name = yitian
age = 20
'''
/<code>

另外还有几个read函数,用于从其他地方读取配置。

read_file,从文件读取配置,参数是一个已经打开的文件read_string,从字符串读取配置,参数是一个配置字符串read_dict,从字典读取配置,参数是一个字典

处理数据类型

所有的数据类型都是字符串类型,如果你需要使用其他数据类型,需要自己手动转换。不过你也可以使用getXXX函数来直接获取某种类型的数据,这样的函数有getint、getfloat、getbooloean,如果你需要的话,还可以自己添加自定义数据类型的处理函数。

<code>print(type(config['default']['age']))
print(type(int(config['default']['age'])))
print(type(config['default'].getint('age')))
'''
<class>
<class>
<class>
'''
/<class>/<class>/<class>/<code>

默认值和备用值

在获取值的时候,假如没有这个值,我们可以给get参数添加第二个值来获得一个备用值,这种方法对于getint、getfloat、getboolean方法等同样适用。

但是如果配置文件中存在DEFAULT章节,而且默认章节设置了某个值的话,就会用这里的默认值取代备用值,因此在使用的时候大家要注意一下。

字符串插入

配置文件中可以引用其他选项,可以通过在ConfigParser构造函数中传入interpolation参数来进行控制。

<code>c = configparser.ConfigParser(


interpolation=configparser.ExtendedInterpolation())
c.read_string(s)
print(c['young']['age'])
/<code>

默认的插入是configparser.BasicInterpolation(),可以处理%(value)s格式的选项。这里的第二个age的值会是yitian2.

<code>[DEFAULT]
name = yitian
age = 25
[young]
name = yitian2
age = %(name)s
/<code>

还有一种是configparser.ExtendedInterpolation(),功能更强,可以引用其他章节的选项。它的格式是${value}。这里的第二个age会是yitian,如果要引用本章节的选项,可以省去section:章节,只保留变量名。

<code>[DEFAULT]
name = yitian
age = 25
[young]
name = yitian2
age = ${DEFAULT:name}
/<code>

如果不需要任何插入和转换,可以直接将interpolation指定为None,这样ConfigParser就会原样读取字符串。

<code>c = configparser.ConfigParser(interpolation=None)
/<code>

实用函数

ConfigParser还包含了一些使用函数,在我们处理配置文件的时候非常有用。



还有一些函数不太常用,这里我就不介绍了。对于大部分情况,其实上面这些已经足够用了。如果有什么意见和建议的话,欢迎评论区讨论!