@binancepumpsignais · Post #51501 · 18.03.2026 г., 19:45
| Coin: #PIPPIN/USDT - Short 20x | Entry Targets: 0.09419 Take-Profit Targets: 1) 0.09231 2) 0.09136 3) 0.09042 4) 0.08948 Binance Pumps®
Hashtags
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
Пребарај: #pippin
@binancepumpsignais · Post #51501 · 18.03.2026 г., 19:45
| Coin: #PIPPIN/USDT - Short 20x | Entry Targets: 0.09419 Take-Profit Targets: 1) 0.09231 2) 0.09136 3) 0.09042 4) 0.08948 Binance Pumps®
Hashtags
@binancepumpsignais · Post #51326 · 04.03.2026 г., 12:51
| Coin: #PIPPIN/USDT - Short 20x | Entry Targets: 0.3189 Take-Profit Targets: 1) 0.3125 2) 0.3093 3) 0.3061 4) 0.3029 Binance Pumps®
Hashtags
@binancepumpsignais · Post #51133 · 22.02.2026 г., 18:41
| Coin: #PIPPIN/USDT - Short 20x | Entry Targets: 0.6269 Take-Profit Targets: 1) 0.6143 2) 0.6081 3) 0.6018 4) 0.5955 Binance Pumps®
Hashtags
@binancepumpsignais · Post #51059 · 18.02.2026 г., 14:19
| Coin: #PIPPIN/USDT - Short 20x | Entry Targets: 0.5547 Take-Profit Targets: 1) 0.5436 2) 0.538 3) 0.5325 4) 0.527 Binance Pumps®
Hashtags
@binancepumpsignais · Post #51039 · 17.02.2026 г., 14:30
| Coin: #PIPPIN/USDT - Short 20x | Entry Targets: 0.5345 Take-Profit Targets: 1) 0.5238 2) 0.5185 3) 0.5131 4) 0.5078 Binance Pumps®
Hashtags
@binancepumpsignais · Post #50756 · 01.02.2026 г., 08:32
| Coin: #PIPPIN/USDT - Short 20x | Entry Targets: 0.1784 Take-Profit Targets: 1) 0.1748 2) 0.173 3) 0.1713 4) 0.1695 Binance Pumps®
Hashtags
@binancefuturesignal · Post #35910 · 26.02.2026 г., 03:48
🎯🎯 Non Stop Huge profit on Premium signals for all Premium Members 🔥🔥#PIPPIN/USDT has crossed all the profit targets and made a great profit of 185% 👁🗨Contact @futurechief to enter the Premium Futures & SPOT Group for daily gains
Hashtags
@binancefuturesignal · Post #35887 · 23.02.2026 г., 20:35
🎯🎯Excellent 100% Profit on #PIPPIN/USDT for all Premium Members 🚀🚀It has crossed all the targets 👁🗨Contact @futurechief to enter the premium group & make daily gains
Hashtags
@binancefuturesignal · Post #35842 · 17.02.2026 г., 20:12
🎯🎯Excellent 38% Profit on #PIPPIN/USDT for all Premium Members 🚀🚀It has crossed all the targets 👁🗨Contact @futurechief to enter the premium group & make daily gains
Hashtags
@binancefuturesignal · Post #35667 · 30.01.2026 г., 00:49
🚀 Back to Back Huge Profits are made in the Premium Group 🎯🎯#PIPPIN/USDT has covered all the target to give a Profit of 390% to all Premium Members 👁🗨Contact @futurechief to enter the Premium Futures & SPOT Group for daily gain
Hashtags
@binancefuturesignal · Post #35417 · 09.01.2026 г., 15:05
🎯 PREMIUM RESULT – #PIPPIN/USDT All targets successfully completed. Result: +23% (leverage-based) Back-to-back wins through planned entries and disciplined exits. Premium members traded this step-by-step. 👉@futurechief
Hashtags
@binancefuturesignal · Post #35407 · 09.01.2026 г., 03:09
🎯🎯 Non Stop Huge profit on Premium signals for all Premium Members 🔥🔥#PIPPIN/USDT has crossed all the profit targets and made a great profit of 27% 👁🗨Contact @futurechief to enter the Premium Futures & SPOT Group for daily gains
Hashtags