Python 3 iniプロファイルの読み込み(UTF-8/UTF-8-BOM)


【背景】
Windowsのメモ帳はUTF-8ファイルにBOMヘッダを追加するので、煩わしくて、共通の読取プロファイルのコードを作ります.このエラーを報告する可能性があります.
configparser.MissingSectionHeaderError: File contains no section headers.
file: 'D:\\Python3Project\\ClearWFWatermark\\config\\config.ini', line: 1
'\ufeff[config]'
【config.ini】
[config]
SrcRoot=D:\input
DstRoot=D:\output

【t.py】
#encoding=utf-8
#author: walker
#date: 2018-03-31
#summary:    UTF-8/UTF-8-BOM     
 
import os, sys
from configparser import ConfigParser
 
SrcRoot = r''
DstRoot = r''
 
#      
def ReadConfig(): 
	global SrcRoot, DstRoot
	 
	cfg = ConfigParser()
	# cfg.optionxform = str   #        
	cfgFile = 'config.ini'
	if not os.path.exists(cfgFile):
		input(cfgFile + ' not found')
		sys.exit(-1)
	with open(cfgFile, mode='rb') as f:
		content = f.read()
	if content.startswith(b'\xef\xbb\xbf'):     #    utf8 bom  
		content = content[3:]
	cfg.read_string(content.decode('utf8'))
	if not cfg.sections():
		input('Read config.ini failed...')
		sys.exit(-1)
		 
	SrcRoot = cfg.get('config', 'SrcRoot').strip()          
	if not os.path.exists(SrcRoot):
		print('Error: not exists %s' % SrcRoot)
		sys.exit(-1)
	print('SrcRoot: %s' % SrcRoot)
	 
	DstRoot = cfg.get('config', 'DstRoot').strip()          
	if not os.path.exists(DstRoot):
		print('Error: not exists %s' % DstRoot)
		sys.exit(-1)
	print('DstRoot: %s' % DstRoot)
		 
	print('Read config.ini successed!')
 
if __name__ == '__main__':
	ReadConfig()

【cmd】
λ python3 t.py
SrcRoot: D:\input
DstRoot: D:\output
Read config.ini successed!

【プロファイルを読み込み、二次順序辞書に変換】
# encoding: utf-8
# author: walker
# date: 2018-06-01
# summary:       ,          ,            cfg._sections

import os, sys
from collections import OrderedDict
from configparser import ConfigParser
from pprint import pprint

#       
#         
def ReadConfig():
    cfg = ConfigParser()
    cfg.optionxform = str   #        
    cfgFile = 'config.ini'
    if not os.path.exists(cfgFile):
        input(cfgFile + ' not found')
        sys.exit(-1)
    with open(cfgFile, mode='rb') as f:
        content = f.read()
    if content.startswith(b'\xef\xbb\xbf'):     #    utf8 bom  
        content = content[3:]
    cfg.read_string(content.decode('utf8'))
    if not cfg.sections():
        input('Read config.ini failed...')
        sys.exit(-1)
    
    dic = OrderedDict()
    for section in cfg.sections():
        dic[section] = OrderedDict()
        for option in cfg.options(section):
            dic[section][option] = cfg.get(section, option).strip()

    #pprint(dic) 
    print('Read %s completed!' % cfgFile)
    
    return dic

*** walker ***