ini配置文件是被configParser直接解析然后再加載的,如果只是修改配置文件,并不會改變已經加載的配置
INI文件結構簡單描述
INI文件就是擴展名為“ini”的文件。在Windows系統中,INI文件是很多,最重要的就是“System.ini”、“System32.ini”和“Win.ini”。
該文件主要存放用戶所做的選擇以及系統的各種參數。用戶可以通過修改INI文件,來改變應用程序和系統的很多配置。但自從Windows 95的退出,在Windows系統中引入了注冊表的概念,INI文件在Windows系統的地位就開始不斷下滑,這是因為注冊表的獨特優點,使應用程序和系統都把許多參數和初始化信息放進了注冊表中。但在某些場合,INI文件還擁有其不可替代的地位。
INI文件結構
INI文件是一種按照特點方式排列的文本文件。每一個INI文件結構都非常類似,由若干段落(section)組成,在每個帶括號的標題下面,是若干個以單個單詞開頭的關鍵詞(keyword)和一個等號,等號右邊的就是關鍵字對應的值(value)。其一般形式如下:
[Section1]
KeyWord1 = Valuel
KeyWord2 = Value2
……
[Section2]
KeyWord3 = Value3
KeyWord4 = Value4
其中:[Section1]用來表示一個段落。因為INI文件可能是項目中共用的,所以使用[Section]段名來區分不同用途的參數區。
例如:[Section1]表示傳感器靈敏度參數區;[Section2 ]表示測量通道參數區等等。KeyWord1=value1 用來表示一個參數名和值。
格式
INI文件由節、鍵、值組成。
節
[section]
參數(鍵=值)
name=value
注解
注解使用分號表示(;)。在分號后面的文字,直到該行結尾都全部為注解。
; comment text
linux 配置文件使用 #
注釋;
# comment text
Python ConfigParser
Python 標準庫的 ConfigParser 模塊提供了一套完整的 API 來讀取和操作配置文件。
在python 3 中ConfigParser模塊名已更名為configparser。
configparser模塊支持讀取.conf和.ini等類型的文件。
但是存在一些缺陷,無法識別section的大小寫,無法讀取文件注釋,這樣修帶有注釋的配置文件時就會存在問題。
操作配置文件
配置文件實例化
# 實例化 CoinfigParser 并加載配置文件
config = ConfigParser.SafeConfigParser()
config.read('config.ini')# 讀取配置文件內容,f必須是unicode
config.read_file(f, source=None)
# 從字符串解析配置數據
config.read_string(string, source=’’)
# 從詞典解析配置數據
config.read_dict(dictionary, source=’’)
配置文件的讀取和修改
# sections(): 得到所有的section,并以列表的形式返回
config.sections()# defaults():返回一個包含實例范圍默認值的詞典
config.defaults()# 添加一個新的section
config.add_section(section)# 判斷是否有section
config.has_section(section)# 得到該section的所有option
config.options(section)# items 得到section的所有鍵值對
config.items(option)# 判斷如果section和option都存在則返回True否則False
config.has_option(section, option)# 得到section中option的值,返回為string類型
config.get(section, option, *, raw=False, vars=None[, fallback])# 得到section中option的值,返回為int類型
config.getint(section,option)# 得到section中option的值,返回為float類型
config.getfloat(section,option)# 得到section中option的值,返回為boolean類型
config.getboolean(section, option)# 對section中的option進行更新,如果沒有相應的option,會新增
config.set(section, option, value)# 從指定section移除option
config.remove_option(section, option)# 移除section
config.remove_section(section)
配置文件的寫入
with open("config.ini", "w+") as f:config.write(f)# 將配置信息輸出到標準輸出
config.write(sys.stdout)# 將配置文件輸出到文件
config.write(open('new_book.info','w'))
示例
import threading
import configparser
class Config(object):_instance_lock = threading.Lock()def __init__(self):self.config = configparser.ConfigParser()self.config.read("config.ini")# single mode,the config file must be control by the only onedef __new__(cls, *arg, **kwargs):if not hasattr(Config, "_instance"):with Config._instance_lock:if not hasattr(Config, "_instance"):Config._instance = object.__new__(cls)return Config._instancedef get_config(self, section, k):return self.config.get(section, k)def get_section(self):return self.config.sections()def get_section_all_key(self, section):return self.config.options(section)def add_section(self, section):self.config.add_section(section)def update_k(self, section, k, v):# 更新相應的k,如果沒有對應的k,會自動創建 k,判斷k時不區分大小寫。self.config.set(section, k, v)def remove_section(self, section):self.config.remove_section(section)def remove_k(self, section, k):self.config.remove_option(section, k)def save_config(self):with open("config.ini", "w+") as f:self.config.write(f)
操作字典的方式操作文件
"""生成configparser配置文件 ,字典的形式"""
import configparser
config = configparser.ConfigParser()# 第一種寫法
config["DEFAULT"] = {'ServerAliveInterval': '45','Compression': 'yes','CompressionLevel': '9'}# 第二種寫法
config['bitbucket.org'] = {}
config['bitbucket.org']['User'] = 'hg'# 第三種寫法
config['topsecret.server.com'] = {}
topsecret = config['topsecret.server.com']
topsecret['Host Port'] = '50022' # mutates the parser
topsecret['ForwardX11'] = 'no' # same hereconfig['DEFAULT']['ForwardX11'] = 'yes'# 寫入后綴為.ini的文件
with open('example.ini', 'w') as configfile:config.write(configfile)