首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >重新实现QSqlTableModel.setQuery

重新实现QSqlTableModel.setQuery
EN

Stack Overflow用户
提问于 2013-07-26 10:28:33
回答 1查看 982关注 0票数 0

我已经重新实现了QSqlTableModel.select(),以在视图中显示模型返回的所有结果:

代码语言:javascript
复制
def select(self):

    self.setTable("videos")

    results = QtSql.QSqlTableModel.select(self)

    self.setHeaderData(5, QtCore.Qt.Horizontal, "", QtCore.Qt.DisplayRole)
    self.setHeaderData(6, QtCore.Qt.Horizontal, "Modification")
    self.setHeaderData(9, QtCore.Qt.Horizontal, "Ajout")

    while self.canFetchMore():
        self.fetchMore()
    return results

我也想对函数setQuey做同样的事情,所以我尝试了这样的方法:

代码语言:javascript
复制
def setQuery(self, query):


    results = QtSql.QSqlTableModel.setQuery(query)
    self.select(results)

    while self.canFetchMore():
        self.fetchMore()
    return results

但我有个例外:

代码语言:javascript
复制
File "/home/djipey/informatique/python/bibli/model.py", line 23, in setQuery
    results = QtSql.QSqlTableModel.setQuery(query)
    TypeError: QSqlTableModel.setQuery(QSqlQuery): first argument of unbound method must have type 'QSqlTableModel'

你能解释一下为什么我有typeError吗?我不太明白。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-07-26 16:19:55

就像您的重写使用两个参数一样,

代码语言:javascript
复制
def setQuery(self, query):

QtSql.QSqlTableModel.setQuery的调用需要两个参数:

代码语言:javascript
复制
results = QtSql.QSqlTableModel.setQuery(self, query)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17879013

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档