Project Icon

component-template

Streamlit自定义组件开发模板与实例

component-template 项目提供Streamlit自定义组件开发模板和示例代码。支持多种Web技术构建前端,并提供Python API接口。项目包含快速启动指南、多个模板示例及与pandas、第三方库集成等用例,便于开发者构建Streamlit组件。此外,还包括社区贡献的模板,涵盖React、Vue、Svelte等框架。

Streamlit 组件模板

这个仓库包含了创建 Streamlit 组件的模板和示例代码。

如需完整信息,请参阅 Streamlit 组件文档

概述

Streamlit 组件由 Python API 和前端(使用您喜欢的任何网络技术构建)组成。

组件可以在任何 Streamlit 应用中使用,可以在 Python 和前端代码之间传递数据,并且可以选择分发到 PyPI 供全世界使用。

  • 用一行 Python 代码创建组件的 API:
import streamlit.components.v1 as components

# 声明组件:
my_component = components.declare_component("my_component", path="frontend/build")

# 使用组件:
my_component(greeting="Hello", name="World")
  • 使用 HTML 和 JavaScript(或 TypeScript、ClojureScript 或任何您喜欢的语言)构建组件的前端。支持 React,但不是必需的:
class MyComponent extends StreamlitComponentBase {
    public render(): ReactNode {
        // 通过 `this.props.args` 访问来自 Python 的参数:
        const greeting = this.props.args["greeting"]
        const name = this.props.args["name"]
        return <div>{greeting}, {name}!</div>
    }
}

快速开始

  • 确保您已安装 Python 3.6+Node.jsnpm
  • 克隆此仓库。
  • 为模板创建新的 Python 虚拟环境:
$ cd template
$ python3 -m venv venv  # 创建 venv
$ . venv/bin/activate   # 激活 venv
$ pip install streamlit # 安装 streamlit
  • 初始化并运行组件模板前端:
$ cd template/my_component/frontend
$ npm install    # 安装 npm 依赖
$ npm run start  # 启动 Webpack 开发服务器
  • 从另一个终端运行模板的 Streamlit 应用:
$ cd template
$ . venv/bin/activate  # 激活之前创建的 venv
$ pip install -e . # 以可编辑模式安装模板
$ streamlit run my_component/example.py  # 运行示例
  • 如果一切顺利,您应该看到类似这样的内容: 快速开始成功
  • 修改 my_component/frontend/src/MyComponent.tsx 中的前端代码。
  • 修改 my_component/__init__.py 中的 Python 代码。

示例

请参阅 template-reactless 目录获取不使用 React 的模板。

请参阅 examples 目录获取使用 pandas DataFrame、集成第三方库等示例。

社区提供的模板

这些模板由社区提供。如果遇到任何问题,请在他们的仓库中提出问题。

贡献

如果您想为这个项目做出贡献,./dev.py 脚本将对您有所帮助。详情请运行 ./dev.py --help

更多信息

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号