Установить свойства виджета в 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
Rovinj, #Croatia🇭🇷
Rovinj interestingly combines rich traditions and modernity, provincial charm and resort status. This city is still a fishing port, so seafood here is the freshest and tastiest.
Sibenik, #Croatia
Sibenik is the only Croatian city and certainly one of several in the world that boasts of having two UNESCO monuments: St. James Cathedral and the fortress.
🇭🇷#Croatia: Croatia has reintroduced compulsory military service after nearly 20 years.
Hundreds of young Croatians have reported for duty, with the first 800 conscripts beginning their two-month basic training at three barracks across the country: Knin, Slunj, and Požega.
Under the new system, up to 4,000 young men will be called up each year for short-term training. Croatian General Kundid said the program will be “very dynamic and very interesting” for conscripts.
Training will include traditional military skills as well as modern capabilities such as basic drone operation, drone defence, and cyberwarfare techniques and countermeasures.
(via @balkanspectator & BBC)
🗺 CROATIA 🇭🇷
A beautiful morning in the town of Rovinj🤩
The historic center of Rovinj is located on a peninsula shaped like a drop. The cathedral is located in the center.
Rovinj interestingly combines rich traditions and modernity, provincial charm, and resort status. This town is still a fishing port, so the seafood here is the freshest and tastiest.
#Croatia
@voyage
🗺 Croatia 🇭🇷
A beautiful morning in the town of Rovinj🤩
The historic center of Rovinj is located on a peninsula shaped like a drop. The cathedral is located in the center.
Rovinj interestingly combines rich traditions and modernity, provincial charm, and resort status. This town is still a fishing port, so the seafood here is the freshest and tastiest.
#Croatia
@voyage
Branko Mataja — Traditional And Folk Songs Of Yugoslavia (Essar Records, 1974)
#guitar#Serbia#Croatia#Yugoslavia
Свой единственный альбом с гитарными интерпретациями народной музыки Югославии Бранко Матая записал у себя дома. Все композиции он исполнил самостоятельно на модифицированной им самим же гитаре. Поэтому «Традиционные и народные песни Югославии» звучат скорее не как урок истории народной музыки родины Матаи, а как интимное, личное общение между исполнителем и слушателем.
Коллекция гитарных медитаций Бранко Матая оставалась в безвестности, пока не была вновь открыта в начале 2000-х. В 2022 году альбом перевыпустил лейбл Numero Group.
🔗Spotify | AppleMusic | Bandcamp
🇰🇬🇭🇷 В рамках официального визита Министра иностранных и европейских дел Республики ХорватияГордана Грлич Радмана в Кыргызскую Республику 12 декабря 2024 года состоялись его переговоры в узком и расширенном составе с Министром иностранных дел Кыргызской РеспубликиЖээнбеком Кулубаевым.
▶️Толук маалымат/Подробнее: mfa.gov.kg
#МИДКР#ТИМ#Kyrgyz_MFA#Kyrgyzstan#Croatia
Friendlies🏳
2026-03-31 23:00 UTC
USA vs. Portugal
Predicted outcome: USA❌
Predicted score: 3:2
Actual: Portugal 0:2
#USA#Portugal
2026-03-31 23:30 UTC
Argentina vs. Zambia
Predicted outcome: Argentina✅
Predicted score: 2:0
Actual: Argentina 5:0
#Argentina#Zambia
2026-04-01 00:00 UTC
Brazil vs. Croatia
Predicted outcome: Brazil✅
Predicted score: 2:1
Actual: Brazil 3:1
#Brazil#Croatia
2026-04-01 01:00 UTC
Mexico vs. Belgium
Predicted outcome: Belgium❌
Predicted score: 1:3
Actual: Draw 1:1
#Mexico#Belgium
#Football#Friendlies