".ini"(即Initialization file),意为初始化文件,常常用于配置文件,包含环境参数、设定参数等等,它十分简洁,而且处理方便,以下是它的基本格式和通过Python对它完成基本的读写操作。

1、ini文件基本格式

下面是一个ini文件

[DEFAULT]
stu5 = 66

[s_name]
ini = 
option = student_name
stu1 = xh
stu2 = wk
stu3 = ky
stu4 = 88

[s_no]
option = student_no
stu2 = 23
stu3 = 34

[s_title]
option

        ini文件有两个基本的组成部分,一是section(块),二是option(项),其中section由方括号和方括号中的名字组成,section的范围是当前方括号到下一个方括号的内容,section与section之间不能重名,区分大小写,option是section中的配置项,由key与value组成的键值对构成,一组key-value构成一个项,如key1 = value1(key与value之间用"="或者":");用" ; " 或者" # "表示注释,在ini文件中有一个特殊的section,[DEFAULT],当其他section获取不到值时用该default下的option作为备用值。

2、ini文件常见操作

        在Python中通过ConfigParser模块对ini进行读写操作,常用方法有: 

        读操作

read(filename) 读取文件内容(当配置文件有中文时,在调用read()方法时,需要传encoding="utf-8-sig"参数 

sections() 获取所有的section,以列表形式返回

options(section)  获取指定section的所有options,以列表形式返回

items(section)  获取指定section的所有键值对,以列表形式返回

get(section, option)  获取指定option的值,返回类型string
        

 写操作

write(fp) 将config对象写入ini文件

add_section(section) 添加一个新的section

set(section, option, value) 对指定section下的某个option赋值

remove_section(section) 删除某个section

remove_option(section, option) 删除某个section下的某个option

3、栗子

# -*- coding: utf-8 -*-
# description: ini 文件处理

import configparser

class dispose_ini:
    """
    封装一个类,进行ini文件的常用操作
    """
    def __init__(self, filepath):
        self._path = filepath
        self.config = configparser.ConfigParser()  # 实例化解析对象
        self.config.read(filepath, encoding='utf-8')  # 读文件

    def get_sections(self):
        """
        获取ini文件所有的块,返回为list
        """
        sect = self.config.sections()
        return sect

    def get_options(self, sec):
        """
        获取ini文件指定块的项
        :param sec: 传入的块名
        :return: 返回指定块的项(列表形式)
        """
        return self.config.options(sec)

    def get_items(self, sec):
        """
        获取指定section的所有键值对
        :param sec: 传入的块名
        :return: section的所有键值对(元组形式)
        """
        return self.config.items(sec)

    def get_option(self, sec, opt):
        """
        :param sec: 传入的块名
        :param opt: 传入项
        :return: 返回项的值(string类型)
        """
        return self.config.get(sec, opt)

    def write_(self):
        """ 将修改后写入文件 """
        with open(self._path, 'w') as fp:
            self.config.write(fp)

    def add_section_(self, sec):
        """
        为ini文件添加新的section, 如果section 已经存在则抛出异常
        :param sec: 传入的块名
        :return: None
        """
        self.config.add_section(sec)
        self.write_()

    def set_option(self, sec, opt, value):
        """
        对指定section下的某个option赋值
        :param sec: 传入的块名
        :param opt: 传入的项名
        :param value: 传入的值
        :return:  None
        """
        self.config.set(sec, opt, value)
        self.write_()  # 写入文件

    def remove_sec(self, sec):
        """
        删除某个section
        :param sec: 传入的块名
        :return: bool
        """
        self.config.remove_section(sec)
        self.write_()  # 写入文件

    def remove_opt(self, sec, opt):
        """
        删除某个section下的某个option
        :param sec: 传入的块名
        :param opt: 传入的项名
        :return: bool
        """
        self.config.remove_option(sec, opt)
        self.write_()  # 写入文件

if __name__ == '__main__':
    # 加载文件, 初始化
    dis = dispose_ini('./demo.ini')

    # 获取ini文件所有的section
    print(dis.get_sections())

    # 获取指定section的所有options
    print(dis.get_options('s_name'))

    # 获取指定section的所有键值对
    print(dis.get_items('s_name'))

    # 获取指定section指定option的值
    print(dis.get_option('s_name', 'stu4'))

    # 对指定option赋值
    dis.set_option('s_name', 'stu7', '88')

    # 删除指定section
    dis.remove_sec('s_title')

    # 增加section
    dis.add_section_('s_title')

    # 删除指定option
    dis.remove_opt('s_name', 'stu7')