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

Резултати

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

Пребарај: #selfhost

当前筛选 #selfhost清除筛选
1900的灯泡店💡

@justfuning1900 · Post #547 · 07.12.2024 г., 03:38

我VPS上的Selfhost服务 以前刚玩博客的时候用的 Wordpress 作为博客系统,基本上都搭建在一些互联网的公益服务上,如今还记得就是 wpoak 这个平台,不过这些服务难抵时间漫长,大多因为成本问题关门大吉了。 所以之后开始自己买 VPS 进行博客程序部署,也开始慢慢重视起数据的重要性和自我保有。 刚开始 VPS 还是玩的非常简单,实例化完成后便用 lnmp 等程序一键装好 PHP 环境,然后下载上传 WordPress 安装程序便算完事了,后来接触的多了才知道 VPS 能做的事情元远不止于此。 后来我开始接触到 Docker,然后研究各种 Selfhost 的应用、服务。 文章地址:https://1900.live/wo-vpsshang-de-selfhostfu-wu/ #Docker#Selfhost

TONlines – News

@tonlines · Post #7031 · 02.05.2025 г., 18:31

Tonnel Network Chooses Self-Hosting Over High Vercel Costs #Vercel#SelfHost Tonnel Network switched to self-hosting their Marketplace MiniApp due to costly charges from Vercel exceeding $1000. They opted for a more economical server rental option. Source: link @tonlines

AppPie

@AppPie · Post #2184 · 14.10.2024 г., 04:02

Dokploy —— Vercel, Netlify 和 Heroku 的开源替代方案 🔗GitHub Dokploy 是一款免费且可自托管的平台即服务(PaaS),简化了应用程序和数据库的部署与管理。 功能特点 Dokploy提供多项功能,让你的工作更加轻松。 • 应用程序:部署任何类型的应用程序 (Node.js、PHP、Python、Go、Ruby等)。 • 数据库:创建并管理支持 MySQL、PostgreSQL、MongoDB、MariaDB、Redis 的数据库。 • 备份:为数据库自动备份至外部存储位置。 • Docker Compose:原生支持Docker Compose,管理复杂应用程序。 • 多节点:使用Docker Swarm管理集群,将应用扩展至多个节点。 • 模板:一键部署开源模板 (Plausible、Pocketbase、Calcom等)。 • Traefik 集成:自动与 Traefik 集成,用于路由和负载均衡。 • 实时监控:监控每个资源的 CPU、内存、存储和网络使用情况。 • Docker 管理:轻松部署和管理Docker容器。 • CLI/API:通过命令行或 API 管理你的应用程序和数据库。 • 通知:在部署成功或失败时收到通知 (支持Slack、Discord、Telegram、Email等)。 • 多服务器:远程部署并管理应用程序到外部服务器。 • 自托管:将 Dokploy 自托管在你的 VPS 上。 文档 访问 docs.dokploy.com 开始使用。 许可证 Apache License 2.0。 #GitHub#OpenSource#Dokploy#Docker#SelfHost 📮 频道 @AppPie