以下代码会创建一个QTableView
。然后创建QAbstractTableModel
的实例并将其分配给它作为其模型。最后,QItemDelegate
已分配给QTableView
。
列0正在填充QLineEdit
。第1列填充QComboBox
。
但即使QLineEdit
分配了自定义文本值,QLineEdit
仍为空白。 QComboBox
正确地获得三项内容并不会发生:'某处',' Over',' The Rainbow'。
使用文本预先填充第0列QLineEdits应该怎么做?
from PyQt4 import QtCore, QtGui
app = QtGui.QApplication([])
class Delegate(QtGui.QItemDelegate):
def __init__(self):
QtGui.QItemDelegate.__init__(self)
def createEditor(self, parent, option, index):
if index.column()==0:
lineedit=QtGui.QLineEdit(parent)
lineedit.setText('Somewhere over the rainbow')
return lineedit
elif index.column()==1:
combo=QtGui.QComboBox(parent)
combo.addItems(['Somewhere','Over','The Rainbow'])
combo.setCurrentIndex(index.row())
return combo
class Model(QtCore.QAbstractTableModel):
def __init__(self):
QtCore.QAbstractTableModel.__init__(self)
self.items = [[1, 'one', None], [2, 'two', None], [3, 'three', None]]
def rowCount(self, parent=QtCore.QModelIndex()):
return 3
def columnCount(self, parent=QtCore.QModelIndex()):
return 3
def data(self, index, role):
if not index.isValid(): return
row = index.row()
column = index.column()
if role == QtCore.Qt.DisplayRole:
return self.items[row][column]
tableModel=Model()
tableView=QtGui.QTableView()
tableView.setModel(tableModel)
tableView.setItemDelegate(Delegate())
for row in range(tableModel.rowCount()):
for column in range(tableModel.columnCount()):
index=tableModel.index(row, column)
tableView.openPersistentEditor(index)
tableView.show()
app.exec_()
非常感谢法比奥的伎俩。
工作代码发布在下面。
我们不应该在Delegate.createEditor()
方法中处理值赋值,而应该实现Delegate.setEditorData(editor, index)
。
在setEditorData
内,我们可以同时获取index.column()
和index.row()
以及使用self.items
参数index
<访问模型使用的value = index.model().items[row][column]
变量/ p>
from PyQt4 import QtCore, QtGui
app = QtGui.QApplication([])
class Delegate(QtGui.QItemDelegate):
def __init__(self):
QtGui.QItemDelegate.__init__(self)
def createEditor(self, parent, option, index):
if index.column()==0:
lineedit=QtGui.QLineEdit(parent)
return lineedit
elif index.column()==1:
combo=QtGui.QComboBox(parent)
return combo
def setEditorData(self, editor, index):
row = index.row()
column = index.column()
value = index.model().items[row][column]
if isinstance(editor, QtGui.QComboBox):
editor.addItems(['Somewhere','Over','The Rainbow'])
editor.setCurrentIndex(index.row())
if isinstance(editor, QtGui.QLineEdit):
editor.setText('Somewhere over the rainbow')
class Model(QtCore.QAbstractTableModel):
def __init__(self):
QtCore.QAbstractTableModel.__init__(self)
self.items = [[1, 'one', 'ONE'], [2, 'two', 'TWO'], [3, 'three', 'THREE']]
def flags(self, index):
return QtCore.Qt.ItemIsEnabled | QtCore.Qt.ItemIsSelectable | QtCore.Qt.ItemIsEditable
def rowCount(self, parent=QtCore.QModelIndex()):
return 3
def columnCount(self, parent=QtCore.QModelIndex()):
return 3
def data(self, index, role):
if not index.isValid(): return
row = index.row()
column = index.column()
if role == QtCore.Qt.DisplayRole or role == QtCore.Qt.EditRole:
return self.items[row][column]
tableModel=Model()
tableView=QtGui.QTableView()
tableView.setModel(tableModel)
tableView.setItemDelegate(Delegate())
for row in range(tableModel.rowCount()):
for column in range(tableModel.columnCount()):
index=tableModel.index(row, column)
tableView.openPersistentEditor(index)
tableView.show()
app.exec_()
答案 0 :(得分:1)
项委托通过setEditorData
方法设置编辑器数据,该方法获取模型数据并将其设置为编辑器。在这种情况下,项委托获取模型数据(可能为空)并将其设置为QLineEdit
,因此它设置一个空字符串。
如果要在编辑器中初始化数据,则必须重新实现setEditorData
,或初始化模型中的数据。
对于QComboBox
,项目会正确显示,因为setEditorData
不会更改组合框的项目。通常,您必须重新实现setEditorData
以根据模型数据设置组合框的当前索引。
我建议您阅读文档:Model/View Programming和Delegate Classes