按下按钮时调用函数

Posted

技术标签:

【中文标题】按下按钮时调用函数【英文标题】:Calling a function upon button press 【发布时间】:2013-02-11 09:48:56 【问题描述】:

当我单击btn_brow_3 时,我正在尝试调用函数funcion。我怎么能做到这一点?

运行以下代码时,我收到此错误消息: TypeError: connect() slot argument should be a callable or a signal not "nonetype"

import atexit
import sys
from PyQt4 import QtGui
import os                           # Libreria para manejar directorios del sistema operativo

def funcion(a):
    print "Hola mundo" + str(a)

class Example(QtGui.QMainWindow):

    def __init__(self):
        super(Example, self).__init__()
        
        self.initUI()
        
    def initUI(self):               
        
        exitAction = QtGui.QAction(QtGui.QIcon('c:/prueba gui/resource/logo.png'), 'Exit', self)
        exitAction.setShortcut('Ctrl+Q')
        exitAction.triggered.connect(QtGui.qApp.quit)
        
        btn_brow_1 = QtGui.QPushButton('Browser...', self)
        btn_brow_1.resize(btn_brow_1.sizeHint())
        btn_brow_1.move(300, 50)
        btn_brow_1.clicked.connect(self.showDialog_points)
        
        btn_brow_2 = QtGui.QPushButton('Dir browser', self)
        btn_brow_2.resize(btn_brow_2.sizeHint())
        btn_brow_2.move(300, 80)
        btn_brow_2.clicked.connect(self.showDialog_indir_stl)
        
        btn_brow_3 = QtGui.QPushButton('Dir browser', self)
        btn_brow_3.resize(btn_brow_3.sizeHint())
        btn_brow_3.move(300, 110)
        btn_brow_3.clicked.connect(self.showDialog_outdir_stl)
        
        
        
        
        btn_brow_4 = QtGui.QPushButton('Crear soportes', self)
        btn_brow_4.setGeometry(20, 145, 250, 25)
        #btn_brow_4.clicked.connect(support.main(fname_points, self.fname_stl_indir, self.fname_stl_outdir))
        btn_brow_4.clicked.connect(funcion(12))  # HERE IS THE PROBLEM!
        
        self.le1 = QtGui.QLineEdit(self)
        self.le1.setGeometry(20, 50, 250,21)
        
        self.le2 = QtGui.QLineEdit(self)
        self.le2.setGeometry(20, 80, 250,21)
        
        self.le3 = QtGui.QLineEdit(self)
        self.le3.setGeometry(20, 110, 250,21)
        
        self.statusBar().showMessage("Ready")
        
        self.toolbar = self.addToolBar('Exit')
        self.toolbar.addAction(exitAction)
        
        self.setGeometry(300, 300, 400, 200)
        self.setWindowTitle('Support from points generator')    
        self.show()
        
        
    
    def showDialog_points(self):
        
        self.fname_points = QtGui.QFileDialog.getOpenFileName(self, 'Open points file', '/home')
        self.statusBar().showMessage(str(self.fname_points))
        self.le1.setText(str(self.fname_points))
        self.fname_points = str(self.le1.text())
        print fname_points

    
    def showDialog_indir_stl(self):
        
        self.fname_stl_indir = QtGui.QFileDialog.getExistingDirectory(self, 'Select STL INPUT directory', '/home')
        self.statusBar().showMessage(str(self.fname_stl_indir))
        self.le2.setText(str(self.fname_stl_indir))
        self.fname_stl_indir = str(self.le2.text())
        print fname_stl_indir 

    def showDialog_outdir_stl(self):
        
        self.fname_stl_outdir = QtGui.QFileDialog.getExistingDirectory(self, 'Select STL OUTPUT directory', '/home')
        self.statusBar().showMessage(str(self.fname_stl_outdir))
        self.le3.setText(str(self.fname_stl_outdir))
        self.fname_stl_outdir = str(self.le3.text())
        print fname_stl_outdir 
  
def main():
    
    app = QtGui.QApplication(sys.argv)
    ex = Example()
    
    
    sys.exit(app.exec_())
    
if __name__ == '__main__':
    main()

【问题讨论】:

【参考方案1】:

Qt 信号可以有参数,这些参数将传递给它们所连接的插槽;例如,新值作为信号 changed 中的参数。因此,虽然您可以拥有一个带参数的槽,但在将信号连接到该槽时,您不能定义它们的实际值,因为它们将在发出信号时定义。

为了在连接时定义一个参数,你可以使用一个额外的函数,它只使用定义的参数调用原始函数:

def wrapper():
    funcion(12)

def funcion(a):
    print "Hola mundo" + str(a)

[...]
btn_brow_4.clicked.connect(wrapper)

附带说明:wrapper 此处不使用大括号:该函数未被调用,而只是作为参数传递给函数connect。在您的代码中,您调用了您的函数 funcion,它什么都不返回 (=None),它在您的原始代码中被传递给 connect,导致您收到错误消息。

为了更简洁,您还可以使用匿名函数:

btn_brow_4.clicked.connect(lambda: funcion(12))

请注意,Qt 也提供了执行此操作的方法,但(至少对我而言)Python 变体更易于阅读。

编辑:更多信息:http://eli.thegreenplace.net/2011/04/25/passing-extra-arguments-to-pyqt-slot/

【讨论】:

【参考方案2】:

您可以使用以下方法访问相同的:

self.connect(btn_brow_4,Qt.SIGNAL("clicked()"),self.callingFunction)

def callingFunction():
    function(12)

【讨论】:

我建议坚持使用 OP 代码中使用的新式信号/插槽,而不是旧式变体。见pyqt.sourceforge.net/Docs/PyQt4/new_style_signals_slots.html【参考方案3】:

试试这个,

def funcion(a):
 print "Hola mundo" + str(a)

[...]
btn_brow_4.clicked.connect(lambda: funcion(12))

【讨论】:

以上是关于按下按钮时调用函数的主要内容,如果未能解决你的问题,请参考以下文章

Python Kivy:如何在按钮单击时调用函数?

React Native onPress 函数不断被调用

在 discord_components (python) 中单击按钮时调用 python 函数

单击pyfltk中的按钮时如何调用函数

在 Bootstrap 模式中单击按钮时调用 JS 函数

在父按钮单击时调用并执行多个子函数