我试图使用此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
等于Fetchall函数,该函数从上一个SQL查询获取数据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()
。我在做什么错?
我不想在这里自己创建信号,因为数据库结果不是静态的。
最佳答案
问题是您将参数传递给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_())
关于python - 使用数据库和Dict添加菜单和触发器,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/46396422/