从PyQt中的QPushButton获取文本

时间:2012-01-23 22:17:56

标签: python qt pyqt pyqt4 qt-signals

我正在尝试从QtGui.QPushButton对象列表中创建一个简单的键盘。

class XKeyboard(QtGui.QWidget):
  '''Special virtual keyboard for any language.'''
  def __init__(self, parent=None):
    QtGui.QWidget.__init__(self, parent)
    self.MainLayout = QtGui.QVBoxLayout()
    self.TextEntry = QtGui.QTextEdit()
    self.Keyboard = QtGui.QVBoxLayout()
    self.MainLayout.addWidget(self.TextEntry)
    self.MainLayout.addLayout(self.Keyboard)
    self.setLayout(self.MainLayout)

  def addRow(self, keys):
    layout = QtGui.QHBoxLayout()
    buttons = [QtGui.QPushButton(unicode(key)) for key in keys]
    for button in buttons:
      key = keys[buttons.index(button)]
      layout.addWidget(button)
      button.clicked.connect(
          lambda key: self.keyClick(key))
      self.keyClick(key)
    self.Keyboard.addLayout(layout)

  def keyClick(self, key):
    self.TextEntry.insertPlainText(key)

问题是lambda返回False而不是key。我做错了什么?

2 个答案:

答案 0 :(得分:4)

lambda

lambda key: self.keyClick(key)

相当于:

def dummy(key):
    self.keyClick(key)

所以,基本上你接受来自clicked信号的参数,该按钮的returns checked状态为False,因为你没有支票-able按钮,并将其传递给keyClick方法。 keyClick方法在for循环中未收到key参数。

可能的解决方案是将lambda接受两个参数写入一个具有预期值的默认值:

lambda checked, key=key: self.keyClick(key)

为什么你需要做key=key是一个完全不同的主题。来自相关主题的This particular answer(连同其他答案)可能会对此有所了解。

答案 1 :(得分:3)

正确的方法是使用专为此情况设计的QButtonGroup

以下是重写您的示例以使用它的一种方法:

class XKeyboard(QtGui.QWidget):
  '''Special virtual keyboard for any language.'''
  def __init__(self, parent=None):
    QtGui.QWidget.__init__(self, parent)
    self.MainLayout = QtGui.QVBoxLayout()
    self.TextEntry = QtGui.QTextEdit()
    self.Keyboard = QtGui.QVBoxLayout()
    self.MainLayout.addWidget(self.TextEntry)
    self.MainLayout.addLayout(self.Keyboard)
    self.setLayout(self.MainLayout)
    self.buttonGroup = QtGui.QButtonGroup(self)
    self.buttonGroup.buttonClicked[int].connect(self.keyClick)

  def addRow(self, keys):
    layout = QtGui.QHBoxLayout()
    for key in keys:
        key = unicode(key)
        button = QtGui.QPushButton(key)
        self.buttonGroup.addButton(button, ord(key))
        layout.addWidget(button)
    self.Keyboard.addLayout(layout)

  def keyClick(self, key):
    self.TextEntry.insertPlainText(unichr(key))