Установить свойства виджета в 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
🌍 The Canadian city of Winnipeg is nicknamed the "Gateway to the West" because it sits where major rail lines and highways converge—making it a key hub in North American transport geography. ✨
#transport⚡#infrastructure⚡#connectivity⚡#geography⚡#nature⚡#earth
👉subscribe Amazing Geography
👉more Channels
⚡️ Natijalar bilan faxrlanamiz!
Beeline Uzbekistan Opensignal tomonidan 2025-yilning birinchi yarmida Oʻzbekistondagi eng tez mobil internet va barqaror tarmoqqa ega operator sifatida e’tirof etildi!
Buning zamirida ulkan mehnat yotadi: 2024-yil boshidan beri biz 5 850 ta baza stansiyalarini qurish va yangilashga sarmoya kiritdik. Va bu o’z natijasini berdi — mamlakatda o'rtacha yuklab olish tezligi 20,2 Mbit/s!
Ammo gap faqat tezlikda emas —Opensignal ma’lumotlariga ko‘ra, biz O‘zbekistonda eng barqaror tarmoqni taqdim etamiz — uzilishlarsiz va muammolarsiz ulanishingizni ta’minlaymiz.
Bundan tashqari, biz Upload Speed Experience nominatsiyasida yana ikki yetakchi operator bilan birinchi o‘rinni bo‘lishmoqdamiz: 5.8–6.6 Mbit/s yuklash tezligi — bu esa videodarslar, striming, onlayn-o‘yinlar va videoqo‘ng‘iroqlar uchun juda muhim!
Bu ma’lumotlarning barchasi 2025-yilning birinchi yarmida Opensignal tomonidan o‘tkazilgan millionlab real o‘lchovlarga asoslangan.
Biz tez va barqaror internetni mamlakatning barcha hududlarida taqdim etish uchun ishlashda davom etamiz.
• • •
⚡️Гордимся результатами!
Beeline Uzbekistan признан Opensignal оператором с самым быстрым мобильным интернетом и наиболее стабильной сетью в Узбекистане за первую половину 2025 года!
За этим стоит огромная работа: с начала 2024 года мы инвестировали в строительство и обновление 5 850 базовых станций. И это дало результат — средняя скорость скачивания 20,2 Мбит/с в стране!
Но дело не только в скорости — мы обеспечиваем самую стабильную сеть в стране по данным исследования Opensignal, чтобы вы всегда были на связи: без лагов, задержек и сбоев.
Мы также делим первое место с двумя ведущими операторами в номинации Upload Speed Experience — со скоростью 5,8–6,6 Мбит/с, что особенно важно для стримов, онлайн-игр, видеозвонков и всего, что требует стабильной сети.
Все данные основаны на миллионах реальных замеров от Opensignal за первую половину 2025 года.
Мы продолжим работать, чтобы быстрый и стабильный интернет был доступен в каждом уголке страны.
#BeelineUzbekistan#Opensignal#MobileExperience#MobileNetworks#Connectivity#DO1440#AI1440
Myriota Secures $50M Funding
Myriota has successfully raised $50 million in funding for its direct-to-orbit satellite connectivity solutions aimed at the Internet of Things. This funding round took place on December 19, 2024. For more details, visit Myriota.
#Myriota#Funding#Satellite#IoT#Connectivity#SpaceTech#DirectToOrbit#Investment#TechNews#Telecommunications
February Startup Fundraising Highlights
MAVOCO AG raises $11.37M for IoT software solutions. 🛠️
Sirius Medical secures $10.33M for medical innovations. 🏥
Little Otter, focusing on children's mental health, raises $9.50M. 🌱
Lorikeet collects $9M for AI-driven issue resolution tools. 🤖
Easpeed Technology gains $7.92M for aerial imaging advancements. 📷
Digital Entertainment Asset earns $6.44M to enhance labor through gamification. 🎮
SimpliFed raises $4M for virtual breastfeeding support. 👶
EPYR brings in $3.10M for renewable heat solutions. ♻️
Presentation AI receives $3M to streamline presentation creation. 📊
LogicStar AI raises $3M to fix bugs in applications. 🔧
#IoT#Healthcare#MentalHealth#AI#Tech#Startups#Funding#RenewableEnergy#Gaming#Web3#Breastfeeding#Presentation#Efficiency#Innovation#ThermalEnergy#BugFixing#Software#Growth#Connectivity#Crowdsourcing