0
我使用PySide2并希望搜索QListView以获取值并选择该行。就像你可以在QComboBox上使用.findText(string_to_search_for)
一样。 如何搜索Qlistview中的值并返回索引?在Qlistview中查找值的索引
一些额外的信息:
我而QListView模型是实现QAbstractTableModel的我写的。 该模型充满了来自数据库的数据,第一列中的id和第二列中的数据库项目的名称。 QListView只显示第二列。这是我的QTableModel的代码。
from PySide2 import QtGui,QtCore
class TwoColumnTableModel(QtCore.QAbstractTableModel):
def __init__(self, row_data=[], column_data=[], parent=None):
QtCore.QAbstractTableModel.__init__(self, parent)
self.row_data = row_data
self.column_data = column_data
def rowCount(self, parent):
return len(self.row_data)
def columnCount(self, parent):
return len(self.column_data)
def flags(self, index):
return QtCore.Qt.ItemIsEnabled | QtCore.Qt.ItemIsSelectable
def data(self, index, role):
if role == QtCore.Qt.DisplayRole:
row = index.row()
column = index.column()
value = self.row_data[row][column]
self.dataChanged.emit(row, column, [])
return value
def headerData(self, section, orientation, role):
if role == QtCore.Qt.DisplayRole:
if orientation == QtCore.Qt.Horizontal:
if section < len(self.column_data):
return self.column_data[section]
else:
return "TEMP COL"
def insertRows(self, position, rows, data=[], parent=QtCore.QModelIndex()):
self.beginInsertRows(parent, position, position + rows - 1)
for i in range(len(data)):
columns = []
row_column1 = data[i][0]
row_column2 = data[i][1]
columns.insert(0, row_column1)
columns.insert(1, row_column2)
self.row_data.insert(position, columns)
self.endInsertRows()
return True
def removeRows(self, position, rows, parent=QtCore.QModelIndex()):
self.beginRemoveRows()
for i in range(rows):
value = self.row_data[position]
self.row_data.remove(value)
self.endRemoveRows()
return True
QListView - 是一个“视图”类,它显示从某些“模型”类取得的数据,扩展QAbstractItemModel。你使用什么样的模型来为数据提供视图? find方法应该在您正在使用的模型类中实现。 – MihanEntalpo
显示您的代码。 – eyllanesc
@MihanEntalpo我正在使用QTableModel,我编辑了我的帖子以包含代码。 –