在创建websocket连接时,最好开启追踪回溯,不然你都发现不了这个错误!!!
开启这个就相当于可以看到ws得报错信息,我之前没开,一直没报错,花了很长时间解决。
websocket.enableTrace(True)
问题描述:
将websocket的on_open()封装到一个类中,就会出现如题问题。
error from callback <bound method CallAI.on_message of <main.CallAI object at 0x000001D8EDC9B4C8>>: on_message() missing 1 required positional argument: 'message'
File "D:\Anaconda\envs\Game\lib\site-packages\websocket\_app.py", line 343, in _callback
callback(*args)
解决方案
问题出在websocket的_callback方法调用上。
python
def _callback(self, callback, *args):
if callback:
try:
if inspect.ismethod(callback):
callback(*args)
else:
callback(self, *args)
默认是调用函数,然后传入参数。
当on_open(self, ws)是class内的方法时,会把self也当成一个参数传给_callback,这样它就找不到想要的ws,可以把ws设置为一个类的全局变量,不需要传入到on_open中,直接从全局self.ws调用。