Установить свойства виджета в 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
🎬VideoIdeas.ai - Your AI YouTube Content Factory! 🚀
Are you struggling to consistently create engaging YouTube content? 😓 Say goodbye to creator's block forever!
VideoIdeas.ai is the ultimate AI assistant that generates viral-worthy scripts, fresh video ideas, and engaging content in minutes - all in YOUR unique voice and style! 🗣️
🤖 Style Cloning Technology
📝 Complete Scripts in Minutes
💡 Endless Content Ideas
🔍 YouTube SEO Optimization
⏱️Save Hours of Planning
🎯 Strategic Growth Recommendations
📚 Read related articles: VideoIdeas.ai: The Ultimate Guide to Creating Viral YouTube Videos in Your Unique Style (2025) & VideoIdeas.ai Review: The Ultimate AI Tool for YouTube Creators in 2025
▶️ Watch YouTube video: VideoIdeas.ai– How to create viral videos in your unique style
Join thousands of creators who've revolutionized their content strategy with VideoIdeas.ai - from beginners to channels with millions of subscribers!
#YouTubeGrowth#ContentCreation#AIforCreators
Business Idea: Start a YouTube Channel💵
Content:
"📹 Business Idea: YouTube Creator
Start with your smartphone to share what you love!
How to start:
1️⃣ Pick a topic: cooking, gaming, or fitness.
2️⃣ Film simple videos (don’t overthink production!).
3️⃣ Upload consistently—1 video a week to grow your audience.
💰 How to Earn: Ads, sponsorships, affiliate marketing.
📌 Tip: Beginners can use free tools like CapCut for editing."
Hashtags: #YouTubeForBeginners#ContentCreation#VideoMarketing
📸⚠️ 30 - 31 August 2025, we bringing fresh flowers again inside our gorgeous place @laurier.design ♥️
📍The Hague, Netherlands 🇳🇱
Timeslots - on request
You can enjoy location with own team or book photosession with us as model or photographer.
Leave comment for contact and more information if interested 🥰
#portfoliodag#fotografielocatie#networking#contentcreation#styledphotoshoot#styledsession
https://www.instagram.com/p/DLhgREQM51K/?igsh=ajh2MWk1Yjc0N2Y=
🚀 AI TRENDS | YouTube Introduces AI Avatar Tool for Shorts Creators
YouTube has launched a new AI avatar tool designed for Shorts creators, allowing them to generate videos of themselves using prompts. According to NS3.AI, this feature enables creators to produce clips lasting up to eight seconds. The rollout began on Wednesday and is accessible through the YouTube app and YouTube Create. Initially, the tool is available to mobile users worldwide, excluding Europe.
#AI#YouTube#AIAvatar#Shorts#ContentCreation#MobileApp#YouTubeCreate#AITrends#TechNews#CreatorTools
Меньше недели я потратил на изучение генеративных моделей, и вот что уже получается. Задумка, усидчивость и терпение, конечно, важны. Результат может быть невероятным.
#AIVideo#GenerativeAI#RunwayML#AIContent#PikaLabs#CreativeAI#ContentCreation#TechInnovation#DigitalArt#FutureOfContent
AI Video Editor Raises $500K
Diffusion Studio has secured $500K in funding as of December 4, 2024. Their AI Video Editor simplifies video editing with advanced features such as Magic Cut, Text-Based Editing, and Instant Auto-Captioning, catering to creators and businesses aiming to enhance their video production efficiency.
#AI#VideoEditing#Funding#Technology#Creators#Influencers#Business#Automation#Software#Innovation#EditingTools#VideoProduction#TextBasedEditing#AutoCaptioning#Workflow#Engagement#Professional#ContentCreation#Creativity#Efficiency
AI Startup Hits $10K Monthly Revenue
AI project ReelFarm generates viral TikTok videos using templates. Recent success: over $10k MRR within the first month. Case study: an online store achieved 100k+ views without high production costs. Industry trend: growth in accessible, low-cost video creation tools. For aspiring project creators, checklist available.
#AI#Video#Marketing#TikTok#Startup#Viral#MRR#ContentCreation#SocialMedia#Innovation#TechTrends#Entrepreneurship#ReelFarm#DigitalMarketing#BusinessGrowth#MicroSAAS#Entrepreneurs#VideoMarketing#DIY#Creators
AI Marketer Launches for $29
Introducing Nikolai's service, MarketOwl, which provides virtual marketing teams for small businesses. The AI-driven platform automates content creation and identifies potential customers. Currently, it supports around 100 users monthly, generating about $3k in revenue. The concept originated from Nikolai's observations of small companies lacking marketing resources, expertise, and time. After initial failures with a marketing strategy MVP, he pivoted to develop the AI marketer. Engagements in a dedicated subreddit led to high conversion rates for subscriptions. Successful products arise from addressing real audience problems. To effectively enter the market, consider using the Plan-Kapkan consisting of 35 steps for launching.
#MarketOwl#AI#Marketing#ContentCreation#SmallBusiness#SaaS#VirtualTeam#Startup#Entrepreneurship#MVP#ProblemSolving#Automation#CustomerAcquisition#AudienceEngagement#Subscription#Revenue#Strategy#PlanKapkan#BusinessGrowth#MarketingTools