ループ変数 (PyQT で使用するため) に応じて、ループ内に関数を作成したいのですが、関数はループ変数を「逆参照」していません。(私は適切な用語を知らないので、私のずさんさを許してください。) これは簡単な例です:
a = [1, 2, 3, 4]
b = []
for item in a:
func = lambda: print(item)
b.append(func)
print(a)
for func in b:
func()
関数のリストになりたいと思いb
ます。それぞれが対応する要素を出力しますa
(定義時に、a
後で変更されても変更されるべきではありません)。リンクで提案されているように、func = lambda item=item: print(item)
この単純なケースを修正しますが、同じ修正で PyQT ケースを機能させることはできません:
import sys
import xml.etree.ElementTree as ET
from PyQt4 import QtCore, QtGui
class Main(QtGui.QMainWindow):
def __init__(self, parent=None):
QtGui.QMainWindow.__init__(self, parent)
self.tree = ET.fromstring('<root><a>1</a><a>2</a><a>3</a><a>4</a></root>')
self.create_widgets()
self.w = None
def create_widgets(self):
self.buttons = []
# THIS DOESN'T WORK
for value in self.tree.findall('a'):
button = QtGui.QPushButton(value.text)
button.clicked.connect(lambda x=value: self.print_text(x))
self.buttons.append(button)
# THIS DOES WORK:
#values = []
#for value in self.tree.findall('a'):
# values.append(value)
#button = QtGui.QPushButton(values[0].text)
#button.clicked.connect(lambda: self.print_text(values[0]))
#self.buttons.append(button)
#button = QtGui.QPushButton(values[1].text)
#button.clicked.connect(lambda: self.print_text(values[1]))
#self.buttons.append(button)
#button = QtGui.QPushButton(values[2].text)
#button.clicked.connect(lambda: self.print_text(values[2]))
#self.buttons.append(button)
#button = QtGui.QPushButton(values[3].text)
#button.clicked.connect(lambda: self.print_text(values[3]))
#self.buttons.append(button)
box = QtGui.QHBoxLayout()
for i in self.buttons:
box.addWidget(i)
central_widget = QtGui.QWidget()
central_widget.setLayout(box)
self.setCentralWidget(central_widget)
def print_text(self, value):
print(value)
print(value.text)
if __name__ == "__main__":
app = QtGui.QApplication(sys.argv)
myapp = Main()
myapp.show()
sys.exit(app.exec_())
要素を渡したいのですがxml.etree
、ラムダ関数を使用すると、得られるのはFalse
. 各ボタンを明示的に作成すると、すべてが正常に機能します。