0

0

使用 Streamlit 在 HTML 模板中加载本地图片

聖光之護

聖光之護

发布时间:2025-10-15 11:18:30

|

480人浏览过

|

来源于php中文网

原创

使用 streamlit 在 html 模板中加载本地图片

本文档旨在解决在使用 Streamlit 框架开发 Python 应用时,如何通过 HTML 模板加载本地图片的问题。我们将介绍如何配置 Streamlit 以允许静态资源服务,并提供示例代码展示如何在 HTML 模板中使用本地图片。通过本文,你将能够轻松地在 Streamlit 应用中集成本地图片资源。

在使用 Streamlit 构建 Web 应用时,经常需要在 HTML 模板中展示图片。如果图片资源位于本地文件系统中,直接使用相对路径可能无法正确加载。这是因为 Streamlit 默认情况下不提供静态资源服务。为了解决这个问题,我们需要配置 Streamlit 以允许静态资源服务,并确保 HTML 模板中的图片路径指向正确的静态资源位置。

配置 Streamlit 允许静态资源服务

Streamlit 提供了一个配置选项,允许我们启用静态资源服务。通过修改 Streamlit 的配置文件 config.toml,我们可以指定一个目录作为静态资源目录,Streamlit 将会从该目录中提供静态文件,例如图片、CSS 文件和 JavaScript 文件。

立即学习前端免费学习笔记(深入)”;

  1. 找到 config.toml 文件: 该文件通常位于用户根目录下 .streamlit 文件夹中。如果没有该文件,可以手动创建。

  2. 修改 config.toml 文件: 在文件中添加以下配置项:

[server]
enableStaticServing = true

这个配置项告诉 Streamlit 启用静态资源服务。默认情况下,Streamlit 会从名为 "static" 的文件夹中提供静态资源。你也可以通过配置 staticContentDir 修改默认的静态资源目录。

在 HTML 模板中使用本地图片

启用静态资源服务后,我们就可以在 HTML 模板中使用本地图片了。假设我们的项目结构如下:

my_app/
├── app.py
├── static/
│   └── myimage.png
└── .streamlit/
    └── config.toml

其中,app.py 是 Streamlit 应用的主文件,static 文件夹包含静态资源,myimage.png 是我们要加载的图片。

在 app.py 中,我们可以使用 st.markdown 函数将 HTML 模板嵌入到 Streamlit 应用中。HTML 模板中的图片路径应该指向 static 文件夹下的图片文件。

JS超酷图片翻动展示效果
JS超酷图片翻动展示效果

JS超酷图片翻动展示效果,根据鼠标进出图片的方向来控制图片进出的方式,效果超炫,兼容主流浏览器。 使用方法: 1、head区域引用文件 lrtk.css,animation.css 2、在文件中加入!-- 代码 开始 --!-- 代码 结束 --区域代码 3、js代码需要在html代码之后载入public.js,main.js 4、如需修改图片尺寸,直接在lrtk.css第10行修改即可

下载

示例代码:

import streamlit as st

st.title("Cat")

st.markdown("[![Click Me](static/myimage.png)](https://streamlit.io)")

在这个例子中,static/myimage.png 是图片文件的相对路径。由于我们已经启用了静态资源服务,Streamlit 会自动从 static 文件夹中找到 myimage.png 文件,并将其提供给浏览器

完整示例

以下是一个完整的示例,展示如何在 Streamlit 应用中使用 HTML 模板加载本地图片:

  1. 创建 config.toml 文件:

在用户根目录下的 .streamlit 文件夹中创建 config.toml 文件,并添加以下内容:

[server]
enableStaticServing = true
  1. 创建 app.py 文件:
import streamlit as st

bot_template = '''
@@##@@
{{MSG}}
''' user_template = '''
@@##@@
{{MSG}}
''' st.title("Local Image Example") st.markdown(user_template.replace("{{MSG}}", "Hello from User!"), unsafe_allow_html=True) st.markdown(bot_template.replace("{{MSG}}", "Hello from Bot!"), unsafe_allow_html=True)
  1. 创建 static 文件夹:

在与 app.py 文件相同的目录下创建 static 文件夹,并将 ghog1.jpg 图片文件放入该文件夹中。 你需要将你自己的图片命名为ghog1.jpg或者修改上面的代码中引用的文件名。

  1. 运行 Streamlit 应用:

在命令行中运行以下命令:

streamlit run app.py

现在,你应该能够在 Streamlit 应用中看到本地图片了。

注意事项

  • 确保 config.toml 文件位于正确的目录下(用户根目录下的 .streamlit 文件夹)。
  • 确保 HTML 模板中的图片路径指向正确的静态资源位置。
  • 如果图片无法加载,请检查静态资源服务是否已启用,以及图片文件是否存在于指定的静态资源目录中。
  • 使用 unsafe_allow_html=True 参数允许 Streamlit 渲染 HTML 模板。请注意,这可能会带来安全风险,因此请谨慎使用。

总结

通过配置 Streamlit 启用静态资源服务,我们可以轻松地在 HTML 模板中使用本地图片。这使得我们能够更灵活地构建 Streamlit 应用,并集成各种本地资源。希望本文档能够帮助你解决在使用 Streamlit 加载本地图片时遇到的问题。

使用 Streamlit 在 HTML 模板中加载本地图片使用 Streamlit 在 HTML 模板中加载本地图片

相关文章

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

769

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

661

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

764

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

659

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1325

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

549

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

710

2023.08.11

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

1

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

CSS教程
CSS教程

共754课时 | 21.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号