gpt4 book ai didi

python - 在 QtableView 中选中不可编辑的单元格

转载 作者:太空宇宙 更新时间:2023-11-04 05:27:58 25 4
gpt4 key购买 nike

我正在使用 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com