TGTGInsighttelegram intelligenceLIVE / telegram public index
← Python Заметки

TGINSIGHT SIMILAR POSTS

Најди сличен содржај

Изворен канал @pythonotes · Post #381 · 23 окт.

Установить свойства виджета в 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

Hashtags

Резултати

Пронајдени 6 слични објави

Пребарај: #neverland

当前筛选 #neverland清除筛选
I-DLE* UPDATE (SLOW)

@gidle_update · Post #46555 · 29.11.2025 г., 06:13

251128 || Berriz 𝕏 UPDATE [📢] i-dle (아이들) Berriz Community Open a space where i-dle (아이들) and NEVERLAND get closer, the i-dle (아이들) community has opened 🎉 From now on, meet various news about i-dle (아이들) on Berriz! 🔗https://berriz.in/i-dle #idle#아이들#NEVERLAND#네버랜드 #Berriz#베리즈 –🦋 ── @GIDLE_UPDATE ──

I-DLE* UPDATE (SLOW)

@gidle_update · Post #46553 · 29.11.2025 г., 06:08

251128 || Berriz 𝕏 UPDATE 💜 The story of i-dle (아이들) starts at Berriz🪄 Meet the message to NEVERLAND right now🧚‍♂️ Let's fill the moments of i-dle (아이들) and NEVERLAND together at Berriz💫 🔗https://berriz.in/i-dle #idle#아이들#NEVERLAND#네버랜드 #베리즈#Berriz –🦋 ── @GIDLE_UPDATE ──

I-DLE* UPDATE (SLOW)

@gidle_update · Post #46418 · 23.11.2025 г., 08:09

251121 || Berriz 𝕏 UPDATE [📢] i-dle (아이들) Berriz 커뮤니티 COMING SOON i-dle (아이들)과 NEVERLAND가 모여 더 달달해지는 공간, 11월 28일(금) 오후 2시, Berriz에서 만나요✨ #idle#아이들#NEVERLAND#네버랜드 #Berriz#베리즈 @official_i_dle - [📢] i-dle Berriz Community COMING SOON A sweeter space where i-dle and NEVERLAND get together, Let’s meet on Berriz at 2PM (KST), November 28 (Fri)✨ –🦋 ── @GIDLE_UPDATE ──

I-DLE* UPDATE (SLOW)

@gidle_update · Post #46365 · 22.11.2025 г., 15:14

251120 || Berriz Shop 𝕏 UPDATE [📢] i-dle 2026 SEASON'S GREETINGS [i-dle & Soil Co.] Sales Information #아이들 (@official_i_dle) season greeting cultivated for #NEVERLAND👨‍🌾 Now meet it at #Berriz ! 😉Exclusive benefits only for #베리즈 are also prepared 📆Pre-Order : 11.20(THU) 14PM - 11.26(WED) 14PM (KST) 🎁Berriz Pre-Order Benefit : One random card provided from 5 unreleased photo cards 🔗https://kko.kakao.com/251120_idlesg #아이들#idle#시즌그리팅 #SEASONSGREETINGS #idleSoilCo #Berriz#베리즈 –🦋 ── @GIDLE_UPDATE ──

I-DLE* UPDATE (SLOW)

@gidle_update · Post #46120 · 15.11.2025 г., 22:48

251115 || Billboard Korea 𝕏 UPDATE Miyeon's new chapter, where she can even sing about the remnants of love. Billboard Korea opened it together with her. Read our interview with i-dle’s MIYEON on her second solo mini-album MY, Lover at the link below https://www.billboard.co.kr/editorial/interview/article/lover_miyeon/ #MIYEON#미연#idle#MYLover#SayMyName#BillboardKorea#빌보드코리아#NEVERLAND –🦋 ── @GIDLE_UPDATE ──