如何使用动态列宽显示带有PyQt5的数据框

时间:2019-11-08 16:31:30

标签: python pandas dataframe pyqt

我目前正在使用PyQt5在我的Python程序的用户界面上工作,感到有些迷茫。我希望你能帮助我。

我的程序的输出是此示例中的数据框。

df = pd.DataFrame({'A': ['AAAAAAAA11111111', 'xyz', 'xyz'],
                   'B': ['BBBBBBBB11111111', 'xyz', 'xyz'],
                   'C': ['CCCCCCCC11111111', 'xyz', 'xyz'],
                   'D': ['CCCCCCCC11111111', 'xyz', 'xyz']})

我的目标是在用户界面中显示此数据框。列应动态适应用户界面的大小(如在网格布局中)。

由于已经对该主题做出了许多贡献,因此我已经查看了一些示例。例如这样的。

#https://www.youtube.com/watch?v=hJEQEECZSH0

import sys
import pandas as pd
from PyQt5.QtWidgets import QApplication, QTableView
from PyQt5.QtCore import QAbstractTableModel, Qt

df = pd.DataFrame({'A': ['AAAAAAAA11111111', 'xyz', 'xyz'],
                   'B': ['BBBBBBBB11111111', 'xyz', 'xyz'],
                   'C': ['CCCCCCCC11111111', 'xyz', 'xyz'],
                   'D': ['CCCCCCCC11111111', 'xyz', 'xyz']})

class pandasModel(QAbstractTableModel):

    def __init__(self, data):
        QAbstractTableModel.__init__(self)
        self._data = data

    def rowCount(self, parent=None):
        return self._data.shape[0]

    def columnCount(self, parent=None):
        return self._data.shape[1]

    def data(self, index, role=Qt.DisplayRole):
        if index.isValid():
            if role == Qt.DisplayRole:
                return str(self._data.iloc[index.row(), index.column()])
        return None

    def headerData(self, col, orientation, role):
        if orientation == Qt.Horizontal and role == Qt.DisplayRole:
            return self._data.columns[col]
        return None

if __name__ == '__main__':
    app = QApplication(sys.argv)
    model = pandasModel(df)
    view = QTableView()
    view.setModel(model)
    view.resize(800, 600)
    view.show()
    sys.exit(app.exec_())

该程序有效,但是我不明白如何动态地将列的宽度调整为用户界面的宽度。

我将非常感谢您提供一些提示。

0 个答案:

没有答案