问题一
在基础配置的时候并没有出现报错信息,在获取配置参数的时候报错 configparser.NoSectionError: No section:
cfg = ConfigParser()
# cfg.read("ini 配置文件路径")
cfg.read("D:\WorkSpace\xxx\config.ini")
# cfg.get("配置名称", "配置参数")
cfg.get("work_test_01", "num")
"""
相关报错
configparser.NoSectionError: No section: "work_test_01"
"""
解决思路
检查文件配置路径是否有误即可
import os
os.path.exists("D:\WorkSpace\xxx\config.ini")
问题二
获取配置参数的时候出现 GBK 编码错误:UnicodeDecodeError: ‘gbk’ codec can’t decode byte 0x80 in position 30: illegal multibyte sequence
Traceback (most recent call last):
File "D:\ToolSpace\JetBrains\PyCharm 2022.3.3\plugins\python\helpers\pydev\_pydevd_bundle\pydevd_exec2.py", line 3, in Exec
exec(exp, global_vars, local_vars)
File "<input>", line 1, in <module>
File "C:\Users\<MyName>\AppData\Local\Programs\Python\Python37\lib\configparser.py", line 696, in read
self._read(fp, filename)
File "C:\Users\<MyName>\AppData\Local\Programs\Python\Python37\lib\configparser.py", line 1014, in _read
for lineno, line in enumerate(fp, start=1):
UnicodeDecodeError: 'gbk' codec can't decode byte 0x80 in position 30: illegal multibyte sequence
解决思路
使用其他编码格式即可
cfg.read("D:\WorkSpace\xxx\config.ini", encoding="utf-8-sig")
额外知识点
这同样可以解决问题:configparser.MissingSectionHeaderError: File contains no section headers
UTF-8 编码是一种在计算机上存储和传输 Unicode 字符的变长编码方式,它可以表示世界上所有的字符,
包括 ASCII 字符和非 ASCII 字符。
UTF-8-sig 编码是 UTF-8 编码的一种变体,它在 UTF-8 编码的基础上,增加了一个字节序标记(BOM,
Byte Order Mark),用于表示文件的编码格式。BOM 是一个特殊的 Unicode 字符,用于标记文本文件
的编码方式。它通常出现在文本文件的开头,可以帮助其他程序识别文件的编码方式。
区别在于,UTF-8-sig 编码会在文本文件开头添加一个 BOM,而 UTF-8 编码不会添加 BOM。这个 BOM
在某些情况下可能会影响文件的解析,因此有些程序可能不支持 UTF-8-sig 编码,而只支持 UTF-8 编码。
但是,在一些特殊的情况下,如在 Windows 平台上使用某些软件处理文本文件时,UTF-8-sig 编码可能
会更加方便和兼容。