Python之ini配置文件詳解
INI介紹
INI是英文「初始化」(initialization)的縮寫,被用來對作業系統或特定程式初始化或進行參數設置。由節(section)、
鍵(key)、值(value)構成。在windows系統中有很多INI文件,例如「System32.ini」和「Win.ini」,相信大家並不陌生。Python
中操作配置文件的模組為configparser,這個模組可以用來解析與Windows上INI文件結構類似的文件。
關於configparser
在python2中該模組名為Configparser,到python3才改為configparser,該模組是用來解析ini
配置文件的解析器。
其作用就是使用模組中的RawConfigParser()、ConfigParser()、SafeConfigParser()這三個方法(任選一種),創建一
個對象使用對象的方法對指定的配置文件做增刪改查操作。
本次使用的python版本為3.8,編譯器使用pycharm。
INI文件格式
INI配置文件組成:
section:表示一個區塊,由方括弧及方括弧中的名稱組成,section的範圍為當前方括弧到下一個方括弧的內容,如「DEFAULT」,「select」,「connect_mysql」。
-
- 大小寫和空格檢查:section中的名稱在保存和獲取的時候是原樣保存和獲取的,即大小寫不一樣或者空格不一樣等都是不同的section;
- 重複性檢查:同一個配置文件中section名稱不允許重複。
option:表示section中的配置項,由key、分隔符和value組成的鍵值對,如「select」下的「broswer = Chrome」。
- 大小寫檢查:key是大小寫不敏感的,保存進文件的時候會自動將key小寫保存,但value是大小寫敏感的;
- 空格檢查:通過key獲取value時,會自動將文件中的key和value前後空格去掉再進行匹配,即文件中保存為’ broswer = Chrome ‘時,用’broswer’也可以獲取到對應的value值’Chrome’;
- 跨多行檢查:key是不能跨行的,但是value可以跨行,只要第二行及之後行的縮進與第一行不同即可,一直到下一個option為止;
- 重複性檢查:和section一樣,同一section下的key是不允許重複的;
- 分隔符:可以是等號「=」或者冒號「:」。
注釋:行注釋用井號「#」或者分號「;」表示,特別需要注意的是必須得是行開頭(前面可以有空格),用在行中間的就不會算作是注釋了。
DEFAULT:這是一個特殊的section,會用作其他section的option取不到值時的備用值,或者可以理解為它是一個root,其他的section都是它的子section,但不是必須提供的。
讀取配置文件
import os import configparser conf = configparser.ConfigParser() # 類的實例化 curpath = os.path.dirname(os.path.realpath(__file__)) path = os.path.join(curpath,'read.ini') conf.read(path,encoding="utf-8") value = conf['select']['url'] print("通過read方法取得的值為:",value) value = conf.get('login','username') print('通過get方法取得的值:',value) value = conf.items('login') # 讀取一個section中的所有數據,返回一個列表 print("通過items方法取得的值:",value) value = conf.getint('connect_mysql','port') # 指定讀取數據的類型 print("指定數據類型取出的值:",value) section = conf.sections() # 讀取配置文件中所有section print(section)
運行結果
注意:配置文件注釋有中文的,在python3中要加上參數encoding=”utf-8″,不然會報錯。
conf.read(path,encoding="utf-8")
寫入配置文件
import os import configparser conf = configparser.ConfigParser() # 類的實例化 curpath = os.path.dirname(os.path.realpath(__file__)) path = os.path.join(curpath,'read.ini') conf.add_section('login') # 添加一個新的section conf.set('login','username','admin') conf.set('login','password','123123') # 往配置文件寫入數據 conf.write(open(path,'a')) # 保存數據
運行以後查看配置文件,可以看到新的section已經寫入到文件中。
write寫入常用的兩種方式,第一種是刪除原文件內容,重新寫入:w
conf.write(open(path,'w'))
第二種是在原文件基礎上繼續寫入內容,追加模式寫入:a
conf.write(open(path,'a'))