下面的代码创建一个QComboBox
。组合的QStandardItem
使用data_obj
方法与setData
一起设置。更改combo
的当前索引会触发run
方法,该方法会迭代combo
'并显示data_obj
,这会变成Python字典。如何使data_obj
持久?
https://docs.microsoft.com/en-us/office/vba/api/excel.range.address#syntax
app = QApplication(list())
class DataObj(dict):
def __init__(self, **kwargs):
super(DataObj, self).__init__(**kwargs)
class Dialog(QDialog):
def __init__(self, parent=None):
super(Dialog, self).__init__(parent)
self.setLayout(QVBoxLayout())
self.combo = QComboBox(self)
for i in range(5):
combo_item = QStandardItem('item_%s' % i)
data_obj = DataObj(foo=i)
print '..out: %s' % type(data_obj)
combo_item.setData(data_obj, Qt.UserRole + 1)
self.combo.model().appendRow(combo_item)
self.combo.currentIndexChanged.connect(self.run)
self.layout().addWidget(self.combo)
def run(self):
for i in range(self.combo.count()):
item = self.combo.model().item(i, 0)
data_obj = item.data(Qt.UserRole + 1)
print ' ...in: %s' % type(data_obj)
if __name__ == '__main__':
gui = Dialog()
gui.resize(400, 100)
gui.show()
qApp.exec_()
答案 0 :(得分:0)
以下是该问题的可行解决方案:
app = QApplication(list())
class DataObj(dict):
def __init__(self, **kwargs):
super(DataObj, self).__init__(**kwargs)
class Object(object):
def __init__(self, data_obj):
super(Object, self).__init__()
self.data_obj = data_obj
class Dialog(QDialog):
def __init__(self, parent=None):
super(Dialog, self).__init__(parent)
self.setLayout(QVBoxLayout())
self.combo = QComboBox(self)
for i in range(5):
combo_item = QStandardItem('item_%s' % i)
obj = Object(data_obj=DataObj(foo=i))
print '..out: %s' % type(obj.data_obj)
combo_item.setData(obj, Qt.UserRole + 1)
self.combo.model().appendRow(combo_item)
self.combo.currentIndexChanged.connect(self.run)
self.layout().addWidget(self.combo)
def run(self):
for i in range(self.combo.count()):
item = self.combo.model().item(i, 0)
obj = item.data(Qt.UserRole + 1)
print ' ...in: %s' % type(obj.data_obj)
if __name__ == '__main__':
gui = Dialog()
gui.resize(400, 100)
gui.show()
qApp.exec_()