Форум программистов, компьютерный форум, киберфорум
Python: GUI, графика
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
0 / 0 / 0
Регистрация: 03.09.2018
Сообщений: 16
PyQt5

Стиль ячейки

11.08.2020, 11:57. Показов 2138. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый!
Как сделать чтобы при разных значениях оного столбца, поменять цвет ячейки другого?
Один столбец "M1", другой ""M2.
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
    Import sys
from PyQt5 import QtCore, QtGui, QtSql, QtWidgets
#import sportsconnection
 
 
def initializeModel(model):
    model.setTable('hierarhy')
    model.setEditStrategy(QtSql.QSqlTableModel.OnFieldChange)
    model.select()
 
 
def createView(title, model):
    view = QtWidgets.QTableView()
    view.setModel(model)
    view.setWindowTitle(title)
    view.setStyleSheet('background: white')
    return view
 
 
def addrow():
    print
    model.rowCount()
    ret = model.insertRows(model.rowCount(), 1)
    print
    ret
 
 
def findrow(i):
    delrow = i.row()
 
 
if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    db = QtSql.QSqlDatabase.addDatabase('QSQLITE')
    db.setDatabaseName('/opt/task')
    model = QtSql.QSqlTableModel()
 
    delrow = -1
 
    initializeModel(model)
 
    view1 = createView("1", model)
    view1.clicked.connect(findrow)
 
    stm = QtSql.QSqlQueryModel()
    stm.setQuery("SELECT * FROM hierarhy")
    #for stm.record(row) not None
    state = stm.record(1).value("M1")
    square = QtWidgets.QFrame(state)
    if state == 1:
       square.setStyleSheet('background: red')
 
    dlg = QtWidgets.QDialog()
    layout = QtWidgets.QVBoxLayout()
    layout.addWidget(view1)
 
    button = QtWidgets.QPushButton("Добавить")
    button.clicked.connect(addrow)
    layout.addWidget(button)
 
    btn1 = QtWidgets.QPushButton("Удалить")
    btn1.clicked.connect(lambda: model.removeRow(view1.currentIndex().row()))
    layout.addWidget(btn1)
 
    dlg.setLayout(layout)
    dlg.setWindowTitle("Тестовая база")
    dlg.resize(1024, 768)
    dlg.show()
    sys.exit(app.exec_())
Значение проверяю, как сделать (((
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
11.08.2020, 11:57
Ответы с готовыми решениями:

PHPExcel стиль ячейки
Добрый день! Можно ли как то получить стиль ячейки при чтение файла? К примеру А4 жирным начертанием сделана. Как определить что она...

Стиль ячейки Masonry Grid
Добрый день! Делаю сайт на cms Drupal 7 На front page вставил блок типа masonry grid с двумя полями в каждой ячейке - img и taxonomy...

Изменить стиль ячейки в DatagridView
Как мне изменить стиль ячейки(НЕ колонки/строки) например: Столбец 1 1 ячейка - BottomRight 2 ячейка - TopCenter 3 ячейка -...

4
 Аватар для kapbepucm
1567 / 740 / 321
Регистрация: 02.05.2020
Сообщений: 1,660
11.08.2020, 14:23
Можно в модели переопределить data(), в котором определять нужный цвет background-а.
0
0 / 0 / 0
Регистрация: 03.09.2018
Сообщений: 16
11.08.2020, 14:43  [ТС]
а как?
0
 Аватар для kapbepucm
1567 / 740 / 321
Регистрация: 02.05.2020
Сообщений: 1,660
11.08.2020, 15:10
Лучший ответ Сообщение было отмечено fm14mhz как решение

Решение

В данном примере, если в столбике M1 ввести значение "1", то соответствующая ячейка M2 будет подсвечиваться красным:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
import sys
from PyQt5.QtWidgets import *
from PyQt5.QtSql     import *
from PyQt5.QtCore    import *
from PyQt5.QtGui     import *
 
class Model(QSqlTableModel):
  def data(self, index, role):
    if (role == Qt.BackgroundRole):
      if (index.column() == 2):
        if super().data(self.index(index.row(), 1)) == 1:
          return QBrush(Qt.red)
    return super().data(index, role)
 
app = QApplication(sys.argv)
db = QSqlDatabase.addDatabase("QSQLITE")
db.setDatabaseName(":memory:")
db.open()
query = QSqlQuery()
query.exec_("CREATE TABLE table1 (id INTEGER, M1 INTEGER, M2 INTEGER);")
query.exec_("INSERT INTO table1 (id, M1, M2) VALUES (1, 1, 1);")
query.exec_("INSERT INTO table1 (id, M1, M2) VALUES (2, 2, 2);")
model = Model()
model.setTable("table1")
model.select()
window = QTableView()
window.setModel(model)
window.show()
sys.exit(app.exec_())
0
0 / 0 / 0
Регистрация: 03.09.2018
Сообщений: 16
11.08.2020, 16:23  [ТС]
Спасибо!
Переделал под своё - заработало. Учить надо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
11.08.2020, 16:23
Помогаю со студенческими работами здесь

Стиль ячейки dataGridView перед прорисовкой
Здравствуйте, уважаемые! Столкнулась с какой-то глупой проблемой.... Пример прилагаю. Есть две закладки, на первой кнопка, на второй...

PHPExcel: изменить стиль ячейки (полужирный, курсив и т.д.)
Как изменить стиль ячейки (полужирный, курсив и т.д.) и как подогнать размер ячейки под содержимое в PHPExcel

Как яваскриптом менять стиль границы ячейки в таблице?
народ!!! плиз подскажите как яваскриптом менять стиль границы ячейки в таблице при нажатии клавиши мыши?вторую ночь мучаюсь!

Сравнить две ячейки DataGridView и изменить их стиль зависимости от введенных данных
Добрый день! Прошу помочь. Задача состоит в следующем: есть datagridview1 с 10 графами и семью строками. При вводе информации должен быть...

Получение номера строки и столбца ячейки, в которой был изменен стиль
Доброе утро. Реализую редактор таблиц. Есть небольшой дизайнер внешнего вида таблицы. В таблице выбираю несколько ячеек и изменяю их...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru