PyQT5 emit 和 connect的用法詳解
對(duì)于PyQT4, PyQT5在一些使用上有著比較明顯的變化有很大的變化,讓人驚訝是在emit和connect上的一些變化比較有意思,相信也是QT為了更好的和Python相結(jié)合做的改進(jìn)。
先上一張圖:
出現(xiàn) AttributeError: 'TCPWindow' object has no attribute 'connect' 這個(gè)問題說明了PyQT5不在支持PyQT4的鏈接信號(hào)槽方式!
對(duì)于emit使用如下:
class Server(QTcpServer): updateServer= pyqtSignal(list)
self.emit(SIGNAL("updateServer(QString,int)"),msg,length)
上面這個(gè)需要改成
self.updateServer(str,int).emit(msg,length)
注意PyQt4還是有QString這個(gè)東西的,PyQt5我找了半天都沒有了,可以直接用 str 來替代,對(duì)于QString::number 都是直接可以使用 str() 來取代,可以說很方便,更加適應(yīng)Python的風(fēng)格。
對(duì)于connect使用如下(以pushButton為例):
self.connect(self.pb_build_tcp,SIGNAL("released()"),self.CreateServer)
改成:
self.pb_build_tcp.released.connect(self.CreateServer)
以上這篇PyQT5 emit 和 connect的用法詳解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Pandas進(jìn)行數(shù)據(jù)編碼的十種方式總結(jié)
在機(jī)器學(xué)習(xí)中,很多算法都需要我們對(duì)分類特征進(jìn)行轉(zhuǎn)換(編碼),即根據(jù)某一列的值,新增(修改)一列。本文為大家總結(jié)了Pandas中十種數(shù)據(jù)編碼的方式,需要的可以參考一下2022-04-04pandas修改DataFrame列名的實(shí)現(xiàn)方法
這篇文章主要介紹了pandas修改DataFrame列名的實(shí)現(xiàn)方法, 文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02Python實(shí)現(xiàn)模擬登錄及表單提交的方法
這篇文章主要介紹了Python實(shí)現(xiàn)模擬登錄及表單提交的方法,涉及Python正則匹配、cookie及URL操作的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07python的pytest框架之命令行參數(shù)詳解(下)
這篇文章主要介紹了python的pytest框架之命令行參數(shù)詳解,今天將繼續(xù)更新其他一些命令選項(xiàng)的使用,和pytest收集測(cè)試用例的規(guī)則,需要的朋友可以參考下2019-06-06