使用数据库和Dict添加菜单和触发器

问题描述 投票:1回答:1

我正在尝试使用此for循环自动生成菜单:

q3 = connect_menu.addMenu('Q3')
q3menus = {}
x = 0
for element in q3s:
    key = 'Q'+str(x)
    q3menus[key] = QAction(element[7], self)
    q3.addAction(q3menus[key])
    q3menus[key].triggered.connect(lambda: self.main_form.consavesv(q3menus[key].text()))
    x += 1

[q3s等于从最后一个SQL查询获取数据的Fetchall函数

q3s = [(1, 'Q3', '127.0.0.1', 28960, "Server Test Name", '5154', '127.0.0.1:28960', "127.0.0.1:28960 | Server Test Name"), (2, 'Q3', '192.168.1.66', 28960, 'Server Test 2', '5154', '192.168.1.66:28960', '192.168.1.66:28960 | Server Test 2')]

我试图使用字典,该字典会尽可能添加菜单标签,但是当我单击它们时,它们都具有与上一个相同的triggered.connect()

我做错了什么?

我不想在这里自己创建信号,因为数据库结果不是静态的。

python python-3.x sqlite pyqt pyqt5
1个回答
1
投票

问题是您将参数传递给lambda函数的方式,正确的语法是:

f = lambda p_1, p_2, ..., p_n: some operation with p_1, p_2, ..., p_n

在您的情况下,还必须考虑到QAction的触发信号返回了一个称为checked的值,因此您必须在该参数之前添加如下所示:

q3menus[key].triggered.connect(lambda checked, key=key: self.main_form.consavesv(q3menus[key].text()))

除了这种方法之外,还可以使用sender()方法,该方法返回发出信号的对象并直接获得文本,如以下示例所示:

class Example(QMainWindow):
    def __init__(self, parent = None):
        QMainWindow.__init__(self, parent)

        q3s = [(1, 'Q3', '127.0.0.1', 28960, "Server Test Name", '5154', '127.0.0.1:28960', "127.0.0.1:28960 | Server Test Name"), 
        (2, 'Q3', '192.168.1.66', 28960, 'Server Test 2', '5154', '192.168.1.66:28960', '192.168.1.66:28960 | Server Test 2')]
        menubar = self.menuBar()

        q3 = menubar.addMenu("Q")
        q3menus = {}
        for x, element in enumerate(q3s):
            key = 'Q'+str(x)
            q3menus[key] = QAction(element[7], self)
            q3.addAction(q3menus[key])
            q3menus[key].triggered.connect(lambda checked, key=key : self.someFunction(q3menus[key].text()))
            q3menus[key].triggered.connect(self.anotherFuntions)

    def someFunction(self, text):
        print("someFunction {}".format(text))

    def anotherFuntions(self):
        print("anotherFuntions {}".format(self.sender().text()))

if __name__ == '__main__':
    app = QApplication(sys.argv)
    w = Example()
    w.show()    
    sys.exit(app.exec_())
© www.soinside.com 2019 - 2024. All rights reserved.