pyQt5从dict创建按钮连接到具有增值的函数

时间:2017-01-26 15:08:49

标签: python python-3.x pyqt pyqt5

连接我的按钮时遇到问题。我尝试了不同的方式,但我没有到达。有时我的GUI没有显示,存放在缓冲区中。 有时我输出Qt.ConnectionType作为输出,而不是'方法' 或参数1具有意外类型'NoneType'

此脚本用于从Web下载文件。在下载(自我)中,更多的行被注释掉,只是为了尝试我的代码。

class Ui_Qwid(object):
    def setupUi(self, Qwid):
        Qwid.setObjectName("Qwid")
        Qwid.resize(423, 795)
        Qwid.setWindowTitle("Softs de secours")
        self.gridLayoutWidget = QtWidgets.QWidget(Qwid)
        self.gridLayoutWidget.setGeometry(QtCore.QRect(-1, 9, 431, 791))
        self.gridLayoutWidget.setObjectName("gridLayoutWidget")
        self.gridLayout = QtWidgets.QGridLayout(self.gridLayoutWidget)
        self.gridLayout.setContentsMargins(0, 0, 0, 0)
        self.gridLayout.setObjectName("gridLayout")


        for key,val in les_soft.items():

            self.btn = QtWidgets.QPushButton(key)
            self.gridLayout.addWidget(self.btn)
            self.btn.clicked.connect(self.download(key))


    def download(self,key):
        print("on passe par la")
        urllib.request.urlretrieve(les_soft[key],key+".exe")


        local_filename = key
        url = les_soft[key]
        # NOTE the stream=True parameter
        r = requests.get(url, stream=True)
        with open(local_filename, 'wb') as f:
            for chunk in r.iter_content(chunk_size=1024): 
                if chunk: # filter out keep-alive new chunks
                    f.write(chunk)
谢谢你的时间

1 个答案:

答案 0 :(得分:1)

当您将信号连接到其插槽时,不应将已评估的函数传递给它,而应仅传递函数的名称。我还建议连接在继承自QWidget,QMainWindow等的类环境中。

此示例我无法完全重现,但如果我可以概括它,那么创建一个模拟数据的字典。

要获得所需的键,我们使用该对象作为源,并使用函数text()来获取它。

sender()函数获取生成信号的对象,在这种情况下是您按下的按钮。

import sys
from PyQt5 import QtCore

from PyQt5 import QtWidgets


class Ui_Qwid(object):
    def setupUi(self, Qwid):
        Qwid.setObjectName("Qwid")
        Qwid.resize(423, 795)
        Qwid.setWindowTitle("Softs de secours")
        self.gridLayoutWidget = QtWidgets.QWidget(Qwid)
        self.gridLayoutWidget.setGeometry(QtCore.QRect(-1, 9, 431, 791))
        self.gridLayoutWidget.setObjectName("gridLayoutWidget")
        self.gridLayout = QtWidgets.QGridLayout(self.gridLayoutWidget)
        self.gridLayout.setContentsMargins(0, 0, 0, 0)
        self.gridLayout.setObjectName("gridLayout")


class Widget(QtWidgets.QWidget, Ui_Qwid):
    def __init__(self, parent=None):
        super(Widget, self).__init__(parent=parent)
        self.setupUi(self)

        self.les_soft = {'key1': 'url1', 'key2': 'url2', 'key3': 'url3', 'key4': 'url4',
                         'key5': 'key5', 'key6': 'url6', 'key7': 'url7', 'key8': 'url8'}

        for key, val in self.les_soft.items():
            self.btn = QtWidgets.QPushButton(key)
            self.gridLayout.addWidget(self.btn)
            self.btn.clicked.connect(self.download)

    def download(self):
        key = self.sender().text()
        print(key)


if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    w = Widget()
    w.show()
    sys.exit(app.exec_())