吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1300|回复: 2
上一主题 下一主题
收起左侧

[求助] PyQt5 如何使用样式表将 QTableWidget 特定内容的单元格的背景色设置为特定颜色

[复制链接]
跳转到指定楼层
楼主
hrpzcf 发表于 2022-12-20 17:11 回帖奖励
需求是:程序必须设置 QTableWidget 单元格的样式表将单元格背景色统一设置为 cyan,而且对于特定内容的单元格设置特定的背景色,具体见代码注释

[Python] 纯文本查看 复制代码
# coding: utf-8
import sys

from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *


class Main(QMainWindow):
    def __init__(self):
        super().__init__()
        self.resize(230, 100)
        self.table = QTableWidget(2, 2)
        item = QTableWidgetItem("Hello")
        # 设置样式表后下面的 setBackground 方法就没有效果了
        item.setBackground(QColor("green"))
        self.table.setItem(0, 0, item)
        self.setCentralWidget(self.table)
        self.show()


if __name__ == "__main__":
    app = QApplication(sys.argv)

    # 需求是必须设置样式表,且内容为 Hello 的单元格背景色设置为 green
    # 但没有找到办法用样式表实现将内容为 Hello 的单元格背景色设置为 green
    # 且设置了样式表后 __init__ 方法中的 setBackground 就无效了,所以也没法用编程方式设置
    # 样式表该怎么写才能实现?或者使用编程的方式单独设置内容为 Hello 的单元格背景色也可以
    app.setStyleSheet(
        """
        /* 这个样式表必须设置(其实程序还有很多样式表,这里简化了) */
        QTableWidget::item {
            color: black;
            background-color: cyan;
        }

        /* 下面这 2 个样式都不能使内容为 Hello 的单元格背景变为绿色 */
        QTableWidgetItem[text='Hello'] {
            background-color: green;
        }
        QTableWidget::item[text='Hello'] {
            background-color: green;
        }
        """
    )

    main = Main()
    sys.exit(app.exec_())

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

沙发
236A 发表于 2022-12-20 18:19
你得用代码实现设置某行某列的字体及颜色啊
样式表设置的是整个单元格颜色吧
3#
 楼主| hrpzcf 发表于 2022-12-21 14:51 |楼主
236A 发表于 2022-12-20 18:19
你得用代码实现设置某行某列的字体及颜色啊
样式表设置的是整个单元格颜色吧

__init__ 方法里已经对某行某列设置颜色了,但是因为 QApplication.setStyleSheet 设置的样式表里有对 table 的样式,所以代码里设置的颜色没有效果

退而求其次,针对 table 全部使用代码设置颜色,不使用样式表了
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 02:55

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表