一个python写的小程序,在每打开一个文件时,会把此文件名写入到一个ini文件中,方便追踪就哪些文件有被处理过。
这个过程也比较简单,当打开一个文件时
#程序启动时初始化ini操作工具
self.m_debugCfgObj = configparser.ConfigParser()
self.m_debugCfgObj.add_section('mainlist')
self.m_debugItemIndex = 0
每当打开一个文件时,就调用如下函数进行写入一项:
def AddDebugFile(self, filename):
if self.m_debugCfgObj is None:
return
itemname = "item_%05d" % self.m_debugItemIndex
self.m_debugItemIndex = self.m_debugItemIndex + 1
wsval = filename
self.m_debugCfgObj.set(self.m_debugSecName, itemname, wsval)
fp = open(self.m_debugCfgPath, "w")
try:
self.m_debugCfgObj.write(fp)
except Exception as e:
strErr = "Write debug ini file error! "
strErr += str(e)
print(strErr)
这个函数也很简单,就是根据索引号添加一个新项,把传入的文件名写进去而已。
这个函数正常情况下运行很好,但在使用过程中发现,当传入的filename中带有百分号 % 时,
self.m_debugCfgObj.set(self.m_debugSecName, itemname, wsval)这一行竟然挂掉了!
单步跟进去查看,发现了问题所在:
在文件configparser.py文件的 BasicInterpolation 类中,有一函数如下:
def before_set(self, parser, section, option, value):
tmp_value = value.replace('%%', '') # escaped percent signs
tmp_value = self._KEYCRE.sub('', tmp_value) # valid syntax
if '%' in tmp_value:
raise ValueError("invalid interpolation syntax in %r at "
"position %d" % (value, tmp_value.find('%')))
return value
这个函数里把双百分号 %% 换成空的,然后还要检查是否存在单百分号 %,如果存在,就抛出异常,晕!
我修改如下:
def before_set(self, parser, section, option, value):
tmp_value = value.replace('%%', '') # escaped percent signs
tmp_value = self._KEYCRE.sub('', tmp_value) # valid syntax
if '%' in tmp_value:
#raise ValueError("invalid interpolation syntax in %r at "
# "position %d" % (value, tmp_value.find('%')))
pass
return value
直接把抛异常的行注释掉,加个占位符 pass。
修改后保存,再测试程序,顺利通过,由于只是简单测试,所以也没有发现其它什么异常。不知道这个%的检查,究竟是为了规避什么问题,以后碰到时再说吧
2020.9.18更新:
此修改的文件是在 C:\Program Files\Python36\Lib\configparser.py,这个文件我之前也有修改,网址:
https://download.csdn.net/download/jszj/11036554
这个修改是支持注释不被删除掉,由于本文是在下载那个网址之后写的,所以下载那个包里并没有本文所说的修改,可以下载那个包之后,再依照本文进行简单修改即可