Установить свойства виджета в PySide можно не только через соответствующие методы и конструктор класса. Можно их изменять с помощью метода setProperty по имени.
btn = QPushButton("Click Me")
btn.setProperty("flat", True)
Это аналогично вызову
btn.setFlat(True)
Если указать несуществующее свойство, то оно просто создается
btn.setProperty("btnType", "super")
Получить его значение можно методом .property(name)
btn_type = btn.property("btnType")
Когда это может быть полезно?
▫️Можно просто хранить какие то данные в виджете и потом их доставать обратно
widget = QWidget()
widget.setProperty('my_data', 123)
print(widget.property('my_data'))
▫️ Назначая эти свойства разным виджетам можно потом отличить виджеты во время итераци по ним. Например, найти все кнопки со свойством my_data="superbtn".
Но ведь вместо кастомного свойства можно использовать objectName, будет тот же результат.
Да, но y ObjectName есть ограничение - только строки.
▫️ Если нам потребуется не просто поиск а, например, сортировка по числу, то свойства позволяют нам это сделать. Поддерживается любой тип данных
widget.setProperty('my_data', {'Key': 'value'})
widget.setProperty('order', 1)
all_widgets.sort(key=w: w.property('order'))
Но ведь Python позволяет всё вышеперечисленное сделать простым созданием атрибута у объекта
widget.order = 1
widget.my_data = 123
Да, но я думаю что не надо объяснять почему не стоит так делать. К тому же, если у виджета нет свойства то метод .property(name) вернет None, а отсутствующий атрибут выбросит исключение.
▫️ Действительно полезное применение кастомным свойствам - контроль стилей. Здесь атрибутами не обойтись, нужны именно свойства.
Дело в том, что в селекторах стилей можно указывать конкретные свойства виджетов на которые следует назначать стиль.
Просто запустите этот код
from PySide2.QtWidgets import *
if __name__ == "__main__":
app = QApplication([])
widget = QWidget(minimumWidth=300)
layout = QVBoxLayout(widget)
btn1 = QPushButton("Action 1")
btn2 = QPushButton("Action 2")
btn3 = QPushButton("Action 3", flat=True)
layout.addWidget(btn1)
layout.addWidget(btn2)
layout.addWidget(btn3)
# добавим кастомное свойство одной кнопке
btn1.setProperty("btnType", "super")
# добавляем стили
widget.setStyleSheet(
"""
QPushButton[btnType="super"] {
background-color: yellow;
color: red;
}
QPushButton[flat="true"] {
color: yellow;
}
"""
)
widget.show()
app.exec_()
С помощью селектора мы избирательно назначили стили на конкретные кнопки.
Как получить список всех кастомный свойств?
Функция получения списка кастомных свойств отличается от получения дефолтных.
def print_widget_dyn_properties(widget):
for prop_name in widget.dynamicPropertyNames():
property_name = prop_name.data().decode()
property_value = widget.property(property_name)
print(f"{property_name}: {property_value}")
#tricks#qt
Доброго дня, братва ! По итогам матча молодёжки на прошлой неделе скажу от себя пару слов: это была одна из самых качественных поддержек команды за последнее время! Ни дождь, ни будний день не помешали отлично пошизить!
Разнообразный список песен и зарядов, в числе которых «Идёт фанат по городу», с лихвой подхватывали как молодые парни с горящими глазами, так и куча братвы, с которой прошли ни один десяток выездных и домашних матчей, члены ультрас-коллективов, и не только.
У игроков сверкали глаза, чему свидетельствует как ответная реакция после матча, так и статистика встречи.
Мы и дальше будем анонсировать такого рода походы на спортивные мероприятия, в скором времени которых будет ещё больше! Присоединяйтесь к нам и не забывайте, что Fan ID — убийца футбола!
#U_Brigade#Moscow#Spartak
В эту пятницу нас ждет принципиальный матч, хоть это и молодежное первенство по футболу — игра с «гудками» будет такой же ожесточенной по борьбе и накалу страстей как на поле, так и на трибунах!
Когда вы окажетесь на секторе активной поддержки, забудьте о своих телефонах, о срочных публикациях в соц.сети и о прочих делах на полтора часа игрового времени. От первой и до последней минуты матча важен твой голос! Видишь, что кто-то не шизит — сделай замечание и пой вместе с товарищем еще громче!
Этот матч для нас возможность показать отличие игр с настоящими фанатами от тех, куда приходят сторонники геноцида живого футбола!
Пятница. 19:00. «Сапсан Арена». Только красный верх, спартаковский шарф, бешеный настрой на шизу! Слушай команды заходящих и будь на одной волне с торсидой!
До встречи на стадионе!
#U_Brigade#Moscow#Spartak
Приветствуем всех!
Завтра нас ждёт долгожданный день — день, когда на первый за полтора года матч основы мы вернемся на нашу родную трибуну «В»! Никакие шаги на пути к смягчению бойкота наш движ не приемлет, поэтому завтра каждый обязан отдать поддержке всего себя, получить максимум эмоций и зарядить команду перед стартом сезона!
Ждем всех неравнодушных, кто разделяет нашу позицию по Fan ID, на стадионе «Спартак» во вторник! Если нижний ярус раскуплен полностью, то на верхний остаётся много свободных билетов.
Бери с собой шарф и красную футболку! Используйте подготовленный для праздника футбола стафф, слушайте команды заводящих и отложите мобильные устройства до финального свистка!
СНОВА ВСЕ НА СТАДИОН!
#U_Brigade#Moscow#Spartak
#Fratria#Ультра
🇷🇺 ONORE ai CADUTI
Donetsk
Repubblica Popolare di Donetsk
Federazione Russia
5/8/2025
( ⚔️ Qui giace, tra gli altri, Motorola, il mitico comandante del battaglione Sparta ).
#donetsk#Donbass#motorola#russia#europa#Defender#italia#spartan#Spartak
https://t.me/gianlucaprocaccinireport