在今天的python编程中,编辑新代码之后,之前一部分已经运行过的代码出现了问题,显示的是“str”object is not callable的问题,在网上查阅资料之后发现,大多数情况是因为在前面定义了以str命名的变量,导致了覆盖.但是反反复复检查了好几遍,发现并没有定义相应的变量。挣扎了好久终于承认这个问题的出现并不是因为我粗心导致了bug,而是其他方面的问题。
首先说一下,我的项目是关于自然语言处理,用到了正则表达式 ,老师在指导时定义过一个类,将首次匹配到的字符串保存到类中再进行下一步的匹配。代码如下:
import regex as re
class REMatcher(object):
def __init__(self, matchstring):
self.matchstring = matchstring
def search(self, regexp, flag=re.X|re.U):
self.rematch = re.search(regexp, self.matchstring, flag)
return bool(self.rematch)
def match(self, regexp, flag=re.X|re.U):
self.rematch = re.match(regexp, self.matchstring, flag)
return bool(self.rematch)
def group(self,i):
return self.rematch.group(i)
def begin(self, i):
return self.rematch.begin(i)
def end(self, i):
return self.rematch.end(i)
为了保持格式一致,在我后续进行中,我将split和sub函数都加入到了这个类之中。:
def sub(self,i,regexp,j):
self.sub=re.sub(i,j,regexp)
return self.sub
def split(self,i,regexp):
self.split=regexp.split(i,1)
return self.split
提示出错部分的代码是这样的:
bookname = m.group("bookname")
bookname1=m.sub('</u>|<u>','',bookname)
dyn = m.group("dyn")
dyn1 = m.group("dyn1")
dynindex=[dyn1,dyn]
author = m.group("author")
author1=m.sub('</u>|<u>','',author)
排查bug的过程比较漫长。我首先在倒数第二行处添加了print语句输出author,发现到这一步结果仍然正常。随后又仔细查看了sub函数的特点和用法,也没有发现问题。发现在前面的bookname1的语句同样用到了sub函数,但是没有提示错误。所以我试着注释掉这一句,发现果然没有再提示错误。经过两小时的排查终于发现是因为sub函数由于某种原因只能使用一次,而之前我的程序中都是只使用了一次,所以并没发现问题。我仔细查看了老师之前所给出的代码,发现之前我的“格式统一”都是只得其形不得其神,老师的所有代码都是建立在之前整段匹配的字符之上的,而我使用group方法之后对象已经改变,所以自然不再合适。但是因为小白才疏学浅,所以我解决问题时使用了最粗暴的方法——在新文件中引入regex模块,直接调用sub方法,最终解决了问题。
路漫漫其修远兮,以后还要多多努力!