qtableWidget 选中一行边框变为红色 样式表
时间: 2024-10-17 19:13:36 浏览: 33
QTableView QTableWidget 复杂表头(多行表头) 、冻结、固定特定的行
5星 · 资源好评率100%
`QTableWidget` 是 Qt 库中的控件,用于显示表格数据。如果你想让 QTableWidget 中某一行选中时边框变成红色,你可以通过设置样式表(StyleSheet)来实现。在 Python 的 PyQt5 或者 PySide2 中,可以这样做:
首先,你需要获取到需要改变样式的 `QTableWidgetItem` 或者更底层的 `QTableCornerItem`。然后,你可以创建一个样式规则,当单元格被选中时应用这个样式。
下面是一个简单的例子:
```python
from PyQt5.QtWidgets import QApplication, QWidget, QTableWidget, QTableWidgetItem
from PyQt5.QtGui import QColor
from PyQt5.QtCore import pyqtSignal
class CustomTable(QTableWidget):
itemSelected = pyqtSignal(str) # 创建信号,传递选中行的索引
def __init__(self):
super().__init__()
self.itemSelectionChanged.connect(self.update_style) # 连接信号处理函数
def update_style(self):
selection_model = self.selectionModel()
if selection_model.hasSelection(): # 检查是否有选中项
selected_items = selection_model.selectedRows() # 获取选中的行
for index in selected_items:
row = index.row()
item = self.item(row, 0) # 假设我们只关心第一列
item.setBackground(QColor("red")) # 设置背景色为红色
style_sheet = """
QTableCornerItem:selected {
border: 2px solid red;
}
"""
item.setStyleSheet(style_sheet) # 设置样式表,增加红色边框
# 使用 CustomTable
app = QApplication([])
widget = QWidget()
table = CustomTable()
table.itemSelected.connect(lambda index: print(f"Row {index} selected")) # 示例,打印选中行
layout = QVBoxLayout(widget)
layout.addWidget(table)
widget.show()
app.exec_()
```
在这个示例中,当选定某一行时,它的背景会变为红色,并且边框会有一个红色的两像素实线。如果不需要每次都修改样式表,也可以直接在 `CustomTable` 类中添加样式规则,减少每次事件触发时的计算。
阅读全文