- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 PYQT5。我有一个 QtableView 小部件,用于类似于电子表格的快速数据输入。有些列是可编辑的,而其他列(标签等)则不是。我通过子类化 QItemDelegate 非常简单地实现了这一点。
我想做的是,当用户从可编辑单元格中切换时,它将跳过任何不可编辑的单元格并转到下一个可编辑单元格。我想我需要在某处编辑后检查按键事件并确定下一列。或者,当我进入一个不可编辑的单元格时,我应该立即移动到下一个可编辑的单元格。我的代码是:
class Rates_sheet(QDialog, Ui_rates_sheet):
"""Displays rates for the next x days for quick changes"""
#----------------------------------------------------------------------
def __init__(self):
"""Constructor"""
QDialog.__init__(self)
self.ui = Ui_rates_sheet()
self.ui.setupUi(self)
self.ui.num_days.setValue(45)
self.ui.get_avail.clicked.connect(self.make_rate_sheet)
self.ui.publish_avail.clicked.connect(self.publish_rates)
self.populate()
def populate(self):
self.rates_model = QSqlTableModel()
self.rates_model.setTable("rates_sheet")
self.rates_model.select()
self.rates_view = self.ui.rates_grid
self.rates_view.setModel(self.rates_model)
self.rates_view.resizeColumnsToContents()
self.rates_view.setSortingEnabled(True)
self.rates_view.setColumnHidden(0, True)
for x in range(7,12):
self.rates_view.setColumnHidden(x, True)
self.rates_view.horizontalHeader().moveSection(3,10)
self.rates_view.horizontalHeader().moveSection(3,12)
self.rates_view.horizontalHeader().moveSection(13,2)
self.rates_view.setItemDelegate(Tmodel(self))
self.rates_model.setHeaderData(1, Qt.Horizontal, "Date")
self.rates_model.sort(1, Qt.AscendingOrder)
def make_rate_sheet(self):
pass
def publish_rates(self):
pass
class Tmodel(QItemDelegate):
"""Remplement rates_sheet table"""
def __init__(self, parent=None):
QItemDelegate.__init__(self)
def createEditor(self, parent, option, index):
if index.column() == 4:
spinbox = QSpinBox(parent)
spinbox.setRange(1,4)
return spinbox
elif index.column() in [5,6,11,12]:
spinbox = QSpinBox(parent)
spinbox.setRange(49,499)
return spinbox
编辑:
我试图重新实现 QSqlTableModel 以更改标志中的值,但最终出现运行时错误:
class MySqlTableModel(QSqlTableModel):
def __init__(self):
QSqlTableModel.__init__(self)
def flags(self, index):
if index.isValid():
if index.column() == 4:
flags ^= 1
return flags
我得到的错误是:
File "f:\Dropbox\pms\main-5.py", line 2658, in <module>
sys.exit(app.exec_())
builtins.TypeError: invalid result from MySqlTableModel.flags(), NoneType cannot be converted to PyQt5.QtCore.ItemFlags in this context
现在我更糊涂了。
最佳答案
经过几天的努力,答案是您可以成功地重新实现 QsqlTableModel。这是我得出答案的方式。
首先,我在网上看到的建议主要是在 C++ 的 QT 论坛中,您应该重新实现 QsqlQueryModel 而不是 QsqlTableModel。但是随后您必须为 setdata、data、rowcount、columncount、insertrows、deleterows 创建方法,更不用说您自己的标志了。这看起来工作量很大而且容易出错。我无法让它工作。
考虑到以上所有内容都是毫无意义的并且需要大量工作,我从 stackoverflow 中找到了一个代码片段有人试图使用来自 QsqlQueryModel 的 dataChanged 信号,他们被建议覆盖 QsqlTableModel。最后我看到了一个例子,说明如何精确地做我正在尝试的事情。因此我更新了我的代码如下:
class Rates_sheet(QDialog, Ui_rates_sheet):
"""Displays rates for the next x days for quick changes"""
def __init__(self):
"""Constructor"""
QDialog.__init__(self)
self.ui = Ui_rates_sheet()
self.ui.setupUi(self)
self.ui.num_days.setValue(45)
self.ui.get_avail.clicked.connect(self.make_rate_sheet)
self.ui.publish_avail.clicked.connect(self.publish_rates)
self.populate()
def populate(self):
self.rates_model = MySqlTableModel()
self.rates_model.setTable("rates_sheet")
self.rates_model.select()
self.rates_view = self.ui.rates_grid
self.rates_view.setModel(self.rates_model)
self.rates_view.resizeColumnsToContents()
self.rates_view.setSortingEnabled(True)
self.rates_view.setColumnHidden(0, True)
self.rates_view.setItemDelegate(Tmodel(self))
self.rates_model.setHeaderData(1, Qt.Horizontal, "Date")
self.rates_model.sort(1, Qt.AscendingOrder)
def make_rate_sheet(self):
pass
def publish_rates(self):
pass
class MySqlTableModel(QSqlTableModel):
"""Overides QSqlTableModel to make columns not selectable"""
def __init__(self):
QSqlTableModel.__init__(self)
def setData(self, index, value, role=Qt.EditRole):
if role == Qt.EditRole:
value = value.strip() if type(value) == str else value
return super(MySqlTableModel, self).setData(index, value, role)
def flags(self, index):
flags = super(MySqlTableModel, self).flags(index)
if index.column() in (4, 5, 6, 11):
flags |= Qt.ItemIsEditable
else:
flags &= Qt.ItemIsSelectable
return flags
这就是解决方案。我仍在测试,但我还没有发现任何问题。
关于python - 在 QtableView 中选中不可编辑的单元格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38092251/
我正在使用 Qtableview与 QsqlTableModel用于填充表数据。我想根据用户对列标题的选择对列进行排序。 我尝试了QTableView sorting signal?中提到的方法用于获
我试图在 python 中找到一个示例,在其中我可以循环 QTableView 的模型元素并打印整行。我已经找到了如何循环选定的行,但在未选择行时什么也没有。 有人可以帮助我吗?无需告诉我如何创建模型
我正在尝试将 QTableView 中的水平和垂直标题设置为自动换行,但没有任何成功。 我想将所有列设置为相同的宽度(包括垂直标题),以及那些多行文本要自动换行的列。如果单词比列宽,它应该向右省略。
我使用 QTableView 和 QAbstractTableModel 的子类作为它的模型。 我看到(默认情况下)当用户输入内容时,QTableView 开始搜索第一列中输入的文本并将 View 滚
实际上我是 Qt 新手,无法匹配 QMouseEvent与 QTableview 请帮助解决这个问题。 最佳答案 以下是单击表格单元格文本时如何获取表格单元格文本的示例。 假设一个 QTableVie
我有一个 QTableView我需要从中获取 selectionChanged 事件。我似乎无法连接工作。我有: MyWidget.h ... protected slots: void slotL
当用户在 QTableView 中选择一行时是否会发出信号?通过鼠标(单选模型)? 最佳答案 每个 View 都有一个选择模型: QItemSelectionModel * QAbstractItem
我正在使用 QTableView与 QAbstractTableModel和 QSortFilterProxyModel这样我就可以通过单击表格标题对项目进行排序。我想为用户添加选项,通过拖动它们来手
是否可以对 QTableView 的标题进行排序? 我想对水平和垂直标题进行排序。 QTableView 仅提供对列内容进行排序的功能。有没有办法对 View 进行排序,或者我是否必须对底层数据结构进
我对 QT 还很陌生,无法理解 QTableView选择改变信号被处理。我已经设置了一个带有 openGL 小部件和 QTableView 的窗口.我有一个正确填充表格 View 的数据模型类,因此我
我是 qt 的新手,我在 QTtableview 中使用 QStandardItemModel。 请建议, 如何更改行和列标题名称。目前它显示 1,2,3,4 如何让 QStandardItemMod
使用 QTableView和 QAbstractTableModel - 当模型发出 dataChanged对于正在编辑的单元格的事件,用户在单元格中键入的字符串(但未按 Enter 以“提交”编辑)
我有一个带有数据的 QTableView。添加行的最简单方法是什么? 谢谢! 最佳答案 当您使用 som YourModel 在 YourTableView (QTableView) 中显示它时,应该
我正在尝试创建一个可以像在 Excel 中一样放大和缩小的 QTableView。 此处提出了类似的问题:Zooming function on a QWidget 但是,我在 PyQt 而不是 C
我正在尝试在 QTableView 中实现类似于 Excel 的行为,其中在整个当前选择周围绘制了一个边框。我已经尝试过这种感觉就像一百种不同的方法并且不断遇到问题。我可以很容易地绘制边框,但是只要选
我正在写一个简单的 TableView根据 http://harmattan-dev.nokia.com/docs/library/html/qt4/itemviews-addressbook.htm
我有一个基于 QStandardItemModel 的 QTableView。我想将第一列设置为“只读”,将所有其他列设置为可编辑。 我不是 QT 和 OOP 的专家,我在网上和 QT 文档中进行了搜
我有两个相同的 QTableView,其中一个是可排序的。这两个表的最后四列的调整模式设置为 QHeaderView::ResizeToContents。 不可排序的表格列宽看起来是正确的,列标题的左
我在 Sqlite 数据库中有一个表,我使用 QTableview 和 QSqlQueryModel 显示它。第一列需要有一个标题,它是一个复选框,列中的所有项目也需要是复选框。我已将第一列标题实现为
我想在 QTableView 中实现用户可编辑复选框这是使用 QAbstractModel 创建的。我可以分配选中和未选中的复选框,但无法使其可编辑。 标志设置为 QItemIsUserCheckab
我是一名优秀的程序员,十分优秀!