NiceGUI 是一个易于使用的、基于 Python 的 UI 框架,可在您的网络浏览器中显示。 您可以创建按钮、对话框、Markdown、3D 场景、图表等多种元素。
它非常适合微型网络应用、仪表板、机器人项目、智能家居解决方案和类似用途。 您也可以在开发过程中使用它,例如调整/配置机器学习算法或调整电机控制器。
NiceGUI 可通过 PyPI 包、Docker 镜像以及 conda-forge 和 GitHub 获取。
python3 -m pip install nicegui
在 main.py
文件中编写您的 NiceGUI 界面:
from nicegui import ui ui.label('你好,NiceGUI!') ui.button('按钮', on_click=lambda: ui.notify('按钮被点击了')) ui.run()
使用以下命令启动:
python3 main.py
现在可以通过浏览器访问 http://localhost:8080/ 来使用 GUI。 注意:当您修改代码时,NiceGUI 将自动重新加载页面。
文档托管在 https://nicegui.io/documentation,并提供了大量实时演示。
https://nicegui.io 的全部内容都是使用 NiceGUI 自身实现的,
可以通过 docker run -p 8080:8080 zauberzeug/nicegui
在本地启动,或者从此仓库执行 main.py
。
您也可以查看我们的深入示例,了解使用 NiceGUI 可以实现的功能。 在我们的 wiki 中,有一个社区 NiceGUI 项目列表、教程部分、不断增长的 FAQ 列表,以及一些使用 ChatGPT / LLMs 获取 NiceGUI 帮助的策略。
我们 Zauberzeug 喜欢 Streamlit, 但觉得它在状态处理方面过于神奇。 在寻找用 Python 编写简单图形用户界面的替代方案时,我们发现了 JustPy。 虽然我们喜欢这种方法,但对于日常使用来说它太"低级 HTML"了。 不过它启发我们在前端使用 Vue 和 Quasar。
我们基于 FastAPI 构建, 而 FastAPI 本身基于 ASGI 框架 Starlette 和 ASGI 网络服务器 Uvicorn, 因为它们性能出色且易于使用。
本项目的维护得益于所有贡献者和赞助商。 如果您想支持这个项目并在下方展示您的头像或公司标志,请赞助我们。 💖
<p align="center"> <a href="https://github.com/lechler-gmbh"><img src="https://yellow-cdn.veclightyear.com/835a84d5/1b33e79d-ec8b-4e1f-bc33-175b44834f88.png" width="50px" alt="Lechler GmbH" /></a> </p>请考虑这种低门槛的贡献形式。 我们非常感谢您的支持。
感谢您有兴趣为 NiceGUI 做出贡献!我们很高兴有您的加入,并感谢您为使这个项目变得更好所做的努力。
作为一个不断成长的开源项目,我们深知实现我们的目标需要社区的共同努力。因此,我们欢迎各种形式的贡献,无论大小。无论是添加新功能、修复错误、改进文档,还是提出新想法,我们都相信每一份贡献都很重要,都能为我们的项目增添价值。
我们在 CONTRIBUTING.md 文件中提供了详细的贡献指南。我们建议您在做出任何贡献之前仔细阅读,以确保您的工作符合项目的目标和标准。
如果您有任何问题或需要帮助,请随时联系我们。我们随时准备为您提供支持,并指导您完成贡献过程。
有关 NiceGUI 依赖的网络框架列表,请参阅 DEPENDENCIES.md。