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

TGINSIGHT SIMILAR POSTS

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

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

Регулярно приходится писать и ревьюить код, где используется PySide2-6. Заметил, что в подавляющем большинстве случаев настройка создаваемых базовых виджетов происходит через методы. Думаю, всем знаком такой способ. Простой пример с кнопкой: button = QPushButton("Click Me") button.setMinimumWidth(300) button.setFlat(True) button.setStyleSheet("font-size: 20pt") button.setToolTip("Super Button") button.clicked.connect(lambda: print("Button clicked")) Но есть и альтернативный способ - настройка через свойства. Это просто ключевые аргументы конструктора класса. Хоть они и не указаны в документации как аргументы, но они есть) Этот код делает тоже самое но с помощью Property button = QPushButton( "Click Me", minimumWidth=300, flat=True, styleSheet="font-size: 20pt", toolTip="Super Button", clicked=lambda: print("Button clicked"), ) Где это может быть полезно ▫️ Это выглядит более аккуратно и коротко, уже повод использовать ▫️ Может использоваться в заполнении лейаута, когда нам не нужно никакое другое взаимодействие с виджетом и поэтому сохранять его в переменную не требуется. Например, лейбл или кнопка. widget = QWidget(minimumWidth=400) layout = QHBoxLayout(widget) layout.addWidget(QLabel("Button >", alignment=Qt.AlignRight)) layout.addWidget(QPushButton("Click Me", clicked=lambda: print("Button clicked"))) widget.show() Либо так widget = QWidget(minimumWidth=400) layout = QHBoxLayout(widget) for wd in ( QLabel("Button >", alignment=Qt.AlignRight), QPushButton("Click Me", clicked=lambda: ...) ): layout.addWidget(wd) widget.show() ▫️ Можно хранить настройки в каком-то конфиге или генерировать на лету, после чего передавать как kwargs. kwargs = {"text": "Hello " * 30, "wordWrap": True} my_label = QLabel(**kwargs) Как получить полный список доступных свойств? Эта функция распечатает в терминал все свойства виджета и их текущие значения def print_widget_properties(widget): meta_object = widget.metaObject() for i in range(meta_object.propertyCount()): property_ = meta_object.property(i) property_name = property_.name() property_value = property_.read(widget) print(f"{property_name}: {property_value}") #tricks#qt

Hashtags

Резултати

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

Пребарај: #nexalloy

当前筛选 #nexalloy清除筛选
Lsposed Modules Updates Tracker

@lsposed_Modules_Updates_Trackers · Post #6663 · 24.04.2026 г., 03:30

#NexAlloy#ChsBuffer 模块:io.github.chsbuffer.revancedxposed 简介:NexAlloy (ReVanced Xposed) 版本:102-2.0.102 更新时间:2026/04/24 10:11:40 更新日志: 🚀 NexAlloy - Official Transition This release marks the final rebranding of the project and its formal migration to the NexAlloy Organization, introducing a new visual identity and a refined foundation. ⚠️ Data & Configuration (Action Required) S @lsposed_Modules_Updates_Trackers | @lsposed_Geeks_Bot

Lsposed Modules Updates Tracker

@lsposed_Modules_Updates_Trackers · Post #6637 · 22.04.2026 г., 16:30

#NexAlloy#ChsBuffer 模块:io.github.chsbuffer.revancedxposed 简介:NexAlloy (ReVanced Xposed) 版本:101-2.0.101 更新时间:2026/04/22 23:55:33 更新日志: 🚀 NexAlloy - Official Transition This release marks the final rebranding of the project and its formal migration to the NexAlloy Organization, introducing a new visual identity and a refined foundation. ⚠️ Data & Configuration (Action Required) S @lsposed_Modules_Updates_Trackers | @lsposed_Geeks_Bot

Lsposed Modules Updates Tracker

@lsposed_Modules_Updates_Trackers · Post #6611 · 18.04.2026 г., 16:30

#NexAlloy#ChsBuffer 模块:io.github.chsbuffer.revancedxposed 简介:NexAlloy (ReVanced Xposed) 版本:100-2.0.100 更新时间:2026/04/18 23:05:03 更新日志: 🚀 NexAlloy v2.0.100 - Official Transition This release marks the final rebranding of the project and its formal migration to the NexAlloy Organization, introducing a new visual identity and a refined foundation. ⚠️ Data & Configuration (Action Re @lsposed_Modules_Updates_Trackers | @lsposed_Geeks_Bot