无法从QTableWidget

时间:2017-08-08 21:13:47

标签: python pyqt pyqt5 qtableview qtablewidget

问题陈述

我试图从我的QtableWidget中选择数据行并将它们打印到我的控制台,这样我就可以测试一些东西,最终目标是能够绘制数据。但是我永远无法获取整行数据。

背景

我制作了一个可以通过导入特定格式的CSV文件嵌入多个QTableWidgets的GUI。目标是能够从相同或不同的表中的多行中提取数据,然后以并排的方式绘制它们。每行数据都是自己的数据集,并有自己的图,但同一图上会有多个图。

为了完成这个任务,我创建了一个名为CompareWindow的窗口,当一个Qpushbutton调用" Compare"被压了。该窗口提示用户键入表的名称以及他们希望绘制的表中的相应行。

提交此信息后,我有一个我可以参考的字典,它已经保存了所有已经实例化的QTableObjects。其中键是为表连接到相应的表对象的名称。

问题

我试图获取行数据的两个主要方法是......

第一个想法是使用TableObject.selectRow()命令我将遍历我想要的行,但每当我这样做时,它将返回一个非类型。

我尝试的第二种方法是迭代给定的行列,以便通过附加项值来逐个填充列表。但是,当我这样做时,它只重复填充列表中的相同数字,这是我的Qtable中的第一个单元格。

即使我明确地调用某个行或列,我也会获得相同的输出。拉出的输出是.12,这是我的CSV文件中第一个单元格的数字。

以下是我遇到问题的代码。

    def initiateMultiPlot(self, tableV, rowV, PlotV):
    """
        1. Match TableName values with the key values in our TableDB
        2. When we find a  match look at that key's corresponding Table Object, and iterate
        through that objects rows and select the rows specified by rowV
        3.Call plot for those values

    """

    #calls my class and creates a blank figure where eventually we will plot data on
    f = CreateFigure.FigureAssembly()
    print("")
    for i in tableV:
        """
            tableV: is list of strings that represent assigned tablenames [Table1, Table2, Table3]
            rowV: is a list, containing lists representing rows from corresponding Tables the user wishes to plot.
                for example [[1,2],[3,4],[1]] means rows 1,2 from table1, rows 3,4 from table2... so on
            PlotV: is a string that is ethier "box" or "whisker" to tell what method to plot. Default right now 
            is to do a simple boxplot
        """
        print("Creating table instance")

        #Table Dictionary is setup so the names of the Tables (tableV) are the keys of the dictionary
        #and the actual table objects are referenced by these keys
        self.TableOBJ = self.TableDictionary[i]
        print("Data Type for the table object is..................{}".format(type(self.TableOBJ)))

        #empty list that will store our row data
        self.Elements = []
        try:
            for rows in rowV:

                for i in rows:
                    print("rowV value is... {}".format(rowV))
                    print("current row list{}".format(rows))
                    print("i value is {}".format(i))
                    print("itterating")

                    for j in range(self.TableOBJ.columnCount()):
                        print("i value is ...{}".format(i))
                        print("j value is .... {}".format(j))

                        #FIRST idea try selecting entire row of data
                        print("i value is ...{}".format(i))
                        print("j value is .... {}".format(j))

                        #entire row returns none-type
                        EntireRow = self.TableOBJ.selectRow(i)
                        print(EntireRow)

                        #selecteditems

                        #SECOND idea try using for loop and iterating through every value in a row
                        item = self.TableOBJ.itemAt(i,j)

                        #explicit call for (row 1, col 1) and  (row 3, col 3), both which output .12
                        print(self.TableOBJ.itemAt(1,1).text())
                        print(self.TableOBJ.itemAt(3,3).text())
                        print("printing item...... {}".format(item))
                        element = item.text()
                        print(element)

                        #list of .12
                        self.Elements.append(element)

                    #elements = [self.TableOBJ.item(i, j).text() for j in range(self.TableOBJ.columnCount()) if
                    #            self.TableOBJ.item(i, j).text() != ""]
                    #print(elements)

        except Exception as e:
            print(e)

        print(self.Elements)

以下是我的GitHub链接,其中包含我的所有文件:https://github.com/Silvuurleaf/Data-Visualize-Project

问题出现在我的文件Perspective.py中的initiateMultiPlot方法中。 CompareWindow.py文件向我的Perspective.py发送信号并连接到initateMultiPlot。如果有任何需要更深入的解释,请咨询。

1 个答案:

答案 0 :(得分:1)

根据documentation

  

QTableWidgetItem * QTableWidget :: itemAt(int ax,int ay)const

     

返回相当于QPoint(ax,ay)的位置的项目   表格小部件的坐标系,如果指定的点,则返回0   表格小部件中的项目未涵盖。

也就是说,返回给定项目x和y,它们是相对于QTableWidget的图形坐标,显然不是你想要的。

您必须使用item()

  

QTableWidgetItem * QTableWidget :: item(int row,int column)const

     

返回给定行和列的项(如果已设置);   否则返回0。

但是除非你做了以下改变,否则你的情况不会起作用:

class CreateTable(QTableWidget):
     ....
            for j in range(0, m):
                self.item = QTableWidgetItem(str(round(ValList[j], 6)))
                # print("{}, {}".format(i, j))
                self.setItem(i, j, self.item)

为:

class CreateTable(QTableWidget):
     ....
            for j in range(0, m):
                item = QTableWidgetItem(str(round(ValList[j], 6)))
                # print("{}, {}".format(i, j))
                self.setItem(i, j, item)

也就是说,您将self.item更改为item

问题是乍一看错误相当困难,QTableWidget类有item()函数,但是当你使用self.item语句时,你正在替换那个调用,即当python读取时声明它将使用属性而不是函数,所以你得到错误:

  

TypeError' xxx'对象不可调用