1

我编写了一个从数据库获取数据的方法。

def connect():
connection = pymssql.connect(".","sa", "1234","Deneme")
cursor = connection.cursor()
cursor.execute("select BolumAdi from BOLUMLER")
return cursor.fetchone()  //problem is here

此方法从数据库中获取一个数据并使用它:

def main():

    app = QtGui.QApplication(sys.argv)
    edit = QtGui.QLineEdit()
    list = connect()
    completer = QtGui.QCompleter(list,edit)
    edit.setWindowTitle("PyQT QLineEdit Auto Complete")
    edit.setCompleter(completer)
    edit.show()

    sys.exit(app.exec_())

if __name__ == '__main__':
    main()

它运作良好。但是由于上述原因,这仅显示一个数据cursor.fetchone()。当我更改此行时cursor.fetchall(),我可以从数据库中获取所有数据,但这次引发和异常:

TypeError: arguments did not match any overloaded call:
QCompleter(QObject parent=None): argument 1 has unexpected type 'list'
QCompleter(QAbstractItemModel, QObject parent=None): argument 1 has unexpected type 'list'
QCompleter(list-of-str, QObject parent=None): argument 1 has unexpected type 'list'

那么问题是什么?

4

2 回答 2

2

由于它在您使用 fetchone() 时有效,这意味着正在使用 QCompleter 的第三个构造函数。如果 fetchone() 返回一个“记录”,即字符串元组(每个选定的列一个),则这是有意义的。由于 fetchall() 返回一个记录列表,而您只需要每条记录的第一个字段,因此您需要先提取数据:

# strings = connect()  # if fetchone()
strings = [item[0] for item in connect()]  # if fetchall()
completer = QtGui.QCompleter(strings)
于 2015-12-27T16:08:42.433 回答
1

该方法connect()返回一个列表。你想要这个列表中的一个元素:

val = connect()[0]
completer = QtGui.QCompleter(val, edit)   
于 2015-12-27T08:52:49.973 回答