更新python3.8之后,运行logging包,有机会出现如下findCaller() takes from 1 to 2 positional arguments but 3 were given
经过多方搜索,原因为在3.8的版本中,findCaller函数的参数增加了一个stacklevel,由两个输入参数变为三个,因此,在fn, lno, func, sinfo = self.findCaller(stack_info, stacklevel)
等函数调用findCaller()的时候就会输入三个参数,但一旦你重写了findCaller这个函数,进行了自己的定义,但你的输入参数没有修改为3个,在3.8版本下,就会出现findCaller() takes from 1 to 2 positional arguments but 3 were given
这个错误。
解决方法:
- 如果logging包由别的包进行调用,如tensorflow的absl包调用,则需要包作者的更新和维护
- 重写了findCaller函数,则在定义findCaller函数时增加一个输入参数。