pyqt - 更改TableView中的行和单元格颜色

3 投票
1 回答
9434 浏览
提问于 2025-04-17 20:15

我有一个QTableView,里面有三列。第二列是数字,只有三种类型:1、-1和0。我想给这三种数字(1、-1、0)用不同的颜色来标记,让它们的行显示不同的颜色。我该怎么做呢?

 self.tableView = QTableView(self.tabSentimento)
 self.tableView.setGeometry(QRect(550,10,510,700))
 self.tableView.setObjectName(_fromUtf8("TabelaSentimento"))
 self.tableView.setModel(self.model)
 self.tableView.horizontalHeader().setStretchLastSection(True)

备注:我使用了 horizontalheader().setStrechLastSection(True),因为我通过一个按钮把一个已有的csv文件打开到我的表格视图里。

1 个回答

6

你需要在模型里定义颜色,而不是在视图里:

def data(self, index, role):
    ...
    if role == Qt.BackgroundRole:
        return QBrush(Qt.yellow)

补充: 这里有一个可以运行的例子,除了颜色部分是完全借鉴自 http://www.saltycrane.com/blog/2007/06/pyqt-42-qabstracttablemodelqtableview/

from PyQt4.QtCore import *
from PyQt4.QtCore import *
from PyQt4.QtGui import *
import sys

my_array = [['00','01','02'],
            ['10','11','12'],
            ['20','21','22']]

def main():
    app = QApplication(sys.argv)
    w = MyWindow()
    w.show()
    sys.exit(app.exec_())

class MyWindow(QTableView):
    def __init__(self, *args):
        QTableView.__init__(self, *args)

        tablemodel = MyTableModel(my_array, self)
        self.setModel(tablemodel)

class MyTableModel(QAbstractTableModel):
    def __init__(self, datain, parent=None, *args):
        QAbstractTableModel.__init__(self, parent, *args)
        self.arraydata = datain

    def rowCount(self, parent):
        return len(self.arraydata)

    def columnCount(self, parent):
        return len(self.arraydata[0])

    def data(self, index, role):
        if not index.isValid():
            return QVariant()
        # vvvv this is the magic part
        elif role == Qt.BackgroundRole:
            if index.row() % 2 == 0:
                return QBrush(Qt.yellow)
            else:
                return QBrush(Qt.red)
        # ^^^^ this is the magic part
        elif role != Qt.DisplayRole:
            return QVariant()
        return QVariant(self.arraydata[index.row()][index.column()])

if __name__ == "__main__":
    main()

撰写回答