我正在尝试将自定义信号(在TCP
客户端类中)连接到使用服务器发送的数据更新日志的方法等等。
以下是TCP
客户端类的声明:
class CarSocket(QObject):
logSignal = Signal(str, str)
...
def __init__(self, ...):
super(CarSocket, self).__init__()
...
我正在尝试连接到logSignal
的方法:
def addToLog(self, text, mode='NORMAL'):
if mode == 'RAW':
toAdd = text
else:
toAdd = "<p>{}</p> \n <hr> \n".format(text)
self.log.logEdit.append(toAdd)
所以,我在初始化我的应用程序时写了这一行:
self.carSocket.logSignal.connect(self.addToLog)
当我执行它时,我得到了一个非常奇怪的错误:
Traceback (most recent call last):
File "/home/ahmed/workspace/autonomee/main.py", line 286, in <module>
window = MainWindow()
File "/home/ahmed/workspace/autonomee/main.py", line 115, in __init__
self.carSocket.logSignal.connect(self.addToLog)
TypeError: connect() takes exactly 3 arguments (4 given)
[Finished in 0.5s with exit code 1]
任何人都可以提供帮助吗?
必须注意的是,我已经成功地将自定义信号连接到另一个类(使用int,连接到类本身的方法),并且我将“默认”信号与默认插槽连接没有问题(如{{ 1}}或类似的东西)
答案 0 :(得分:8)
我的代码遇到了这个问题,想要贡献我认为的答案。您的CarSocket类中还有一个名为“connect”的函数。尝试重命名该功能,看看会发生什么。
在我的情况下,我的一个发出信号的类也有一个“连接”功能,并重命名它修复了问题。它应该不会引起问题,因为你从Signal()类型本身调用connect,但似乎有问题。
答案 1 :(得分:0)
我在尝试运行程序时遇到同样的错误。看起来很奇怪。我发现只有一个提到here,但没有解决方案。我可以建议你的一件事是旧式connect
仍然可以正常工作:
self.connect(self.carSocket, SIGNAL("logSignal(str, str)"), self, SLOT("addToLog(str, str)"))
可能是PySide的错误。在评论中,人们说他们没有PySide 1.1.2的问题。我也有这个版本和Qt版本4.8.4。