2017-06-18 70 views
0

我在PYQT5上開發了一個集成了posgtresql的桌面應用程序。我絆倒了,該表不顯示值的情況:qtablewidget中的空值

looks like on screen

源代碼:

def createTable(self): 
    self.tableWidget = QTableWidget() 

    conn = psycopg2.connect('host=localhost port=5432 dbname=postgres user=postgres password=12345678') 

    cursor = conn.cursor() 
    query = cursor.execute("SELECT * FROM wave_params") 
    result = cursor.fetchall() 
    for i in result: 
     print(i) 

    rows = len(result) 
    columns = len(result[0]) 
    self.tableWidget.setColumnCount(columns) 
    self.tableWidget.setRowCount(rows) 

    index = 0 
    while query != None: 
     self.tableWidget.setItem(index,0, QTableWidgetItem(query.result[0])) 
     # self.tableWidget.setItem(index, 1, QTableWidgetItem(str(query.value(1)))) 
     # self.tableWidget.setItem(index, 2, QTableWidgetItem(str(query.value(2)))) 
     index = index + 1 



    # table selection change 
    self.tableWidget.doubleClicked.connect(self.on_click) 

@pyqtSlot() 
def on_click(self): 
    print("\n") 
    for currentQTableWidgetItem in self.tableWidget.selectedItems(): 
     print(currentQTableWidgetItem.row(), currentQTableWidgetItem.column(), currentQTableWidgetItem.text()) 

我無法理解。問題是什麼? 謝謝!

+0

[QTableWidgetItem(https://doc.qt.io/qt-5/qtablewidgetitem.html#public-functions)。 – ekhumoro

回答

0

遊標對象沒有屬性結果。代碼結果中的 是包含cursor.fetchall()的返回值的元組列表,並且查詢是cursor.execute()的返回值。 cursor.execute()總是返回無 (請參閱documentation)。你只需要循環的結果,在這裏2個例子:

def createTable(self): 
    self.tableWidget = QTableWidget(self) 

    psycopg2.connect('host=localhost port=5432 dbname=postgres user=postgres password=12345678') 

    cursor = conn.cursor() 
    query = cursor.execute("SELECT * FROM ladestelle") 
    result = cursor.fetchall() 

    rows = len(result) 
    columns = len(result[0]) 
    self.tableWidget.setColumnCount(columns) 
    self.tableWidget.setRowCount(rows) 

    for i, r in enumerate(result): 
     self.tableWidget.setItem(i, 0, QTableWidgetItem(r[0])) 
     self.tableWidget.setItem(i, 1, QTableWidgetItem(str(r[1]))) 
     self.tableWidget.setItem(i, 2, QTableWidgetItem(str(r[2]))) 
    ''' 
    # or simpler 
    for r in range(rows): 
     for c in range(columns): 
      self.tableWidget.setItem(r, c, QTableWidgetItem(str(result[r][c]))) 
    ''' 

    self.tableWidget.doubleClicked.connect(self.on_click)