需要延迟项目更改信号直到我的数据加载
Need to delay the item changed signal till my data is loaded
我正在 table 小部件上加载 mysql 数据库。
我有两个函数连接到我的 QTable 小部件中的项目更改信号。第一个列出已更改的单元格,而第二个用于管理 table 小部件单元格中输入的数据类型,如果输入了错误的数据类型,则会显示错误消息。
问题是在我加载我的数据库之前这些函数工作。有效地存储我不想要的单元格列表并在加载时弹出连续的错误消息。
如何在加载数据库后停止运行函数?
def log_change(self, item):
self.changed_items.append([item.row(),item.column()])
def item_changed(self, Qitem,item):
if (item.column())%2 == 0:
try:
test = float(Qitem.text())
except ValueError:
Msgbox = QMessageBox()
Msgbox.setText("Error, value must be number!")
Msgbox.exec()
Qitem.setText(str(''))
有2个选项:
- 使用标志:
# in constructor
self.is_loading = False
def load_from_db(self):
# in load function
self.is_loading = True
# load from db
# ...
self.is_loading = False
# foo_callback is item_changed by example
def foo_callback(self, arg1, arg2, ...):
if self.is_loading:
return
# do work
- 使用 blockSignals
self.tablewidget.blockSignals(True)
# load from db
# ...
self.tablewidget.blockSignals(False)
我正在 table 小部件上加载 mysql 数据库。
我有两个函数连接到我的 QTable 小部件中的项目更改信号。第一个列出已更改的单元格,而第二个用于管理 table 小部件单元格中输入的数据类型,如果输入了错误的数据类型,则会显示错误消息。
问题是在我加载我的数据库之前这些函数工作。有效地存储我不想要的单元格列表并在加载时弹出连续的错误消息。
如何在加载数据库后停止运行函数?
def log_change(self, item):
self.changed_items.append([item.row(),item.column()])
def item_changed(self, Qitem,item):
if (item.column())%2 == 0:
try:
test = float(Qitem.text())
except ValueError:
Msgbox = QMessageBox()
Msgbox.setText("Error, value must be number!")
Msgbox.exec()
Qitem.setText(str(''))
有2个选项:
- 使用标志:
# in constructor
self.is_loading = False
def load_from_db(self):
# in load function
self.is_loading = True
# load from db
# ...
self.is_loading = False
# foo_callback is item_changed by example
def foo_callback(self, arg1, arg2, ...):
if self.is_loading:
return
# do work
- 使用 blockSignals
self.tablewidget.blockSignals(True)
# load from db
# ...
self.tablewidget.blockSignals(False)