『玩转Streamlit』--会话状态管理
在Web应用开发中,会话管理是一个至关重要的概念,它能够帮助开发者追踪用户在应用中的行为和状态,从而为用户提供更加个性化、连贯且高效的交互体验。
Streamlit作为一个简单而强大的用于快速构建和部署数据科学和机器学习项目,也提供了强大的会话状态管理功能,即st.session_state。
本文将介绍Streamlit里的会话状态管理,包括它是什么、有什么用、在哪些情况下能派上用场,还有使用时要注意些什么。
1. 什么是会话管理
会话管理是一种在Web应用中跟踪用户会话的技术。
当用户与Web应用进行交互时,会话管理机制会创建一个唯一的会话标识符(session ID),并将其存储在用户的浏览器中(通常以Cookie的形式)。
服务器端会根据这个会话标识符来存储和检索与该用户相关的数据,例如用户输入的信息、应用的状态等。
这样,即使用户在多个页面之间跳转,应用也能够记住用户之前的操作和设置,从而实现跨页面的状态保持。
在传统的Web开发中,会话管理通常需要借助服务器端的存储机制(如数据库)和复杂的前端与后端交互逻辑来实现。
然而,Streamlit通过其内置的st.session_state对象,为开发者提供了一种更加简洁、高效的方式来管理会话状态,无需手动处理底层的会话机制。
2. 会话管理的作用
在Streamlit应用中,st.session_state的作用主要体现在以下几个方面:
首先,保持用户输入的状态,当用户在Streamlit应用中输入数据(如文本框中的文字、下拉菜单的选择等)时,这些输入数据会被存储在st.session_state中。
即使用户刷新页面或跳转到其他页面,这些输入数据依然可以被保留下来,从而避免了用户重复输入的麻烦。
其次,实现跨页面的状态共享,在复杂的Streamlit应用中,可能包含多个页面或组件。
通过st.session_state,开发者可以在不同的页面或组件之间共享状态信息。
例如,用户在页面A中选择了一个特定的参数,这个参数可以通过st.session_state传递到页面B,从而实现页面之间的数据交互。
最后,动态更新应用界面,根据用户的行为或应用的逻辑,st.session_state可以动态地更新应用的状态,从而触发界面的重新渲染。
这种动态性使得Streamlit应用能够更加灵活地响应用户的操作,提供更加流畅的交互体验。
3. 会话管理的示例
为了更好地理解st.session_state在Streamlit应用中的实际应用,下面来看看两个具体的示例。
3.1. 用户登录状态管理
假设我们正在开发一个需要用户登录的Streamlit应用。
我们需要在用户登录后记住他们的登录状态,并在应用的各个页面中根据登录状态显示不同的内容。
import streamlit as st
# 初始化登录状态
if "logged_in" not in st.session_state:
st.session_state.logged_in = False
# 登录页面
def login_page():
st.title("登录页面")
username = st.text_input("用户名")
password = st.text_input("密码", type="password")
if st.button("登录"):
if username == "admin" and password == "password": # 简单的登录验证
st.session_state.logged_in = True
st.success("登录成功!")
else:
st.error("用户名或密码错误!")
# 主页面
def main_page():
st.title("主页面")
if st.session_state.logged_in:
st.write("欢迎,你已经登录!")
if st.button("登出"):
st.session_state.logged_in = False
st.rerun() # 重新运行应用以更新登录状态
else:
st.write("你尚未登录,请先登录。")
login_page()
# 运行主页面
main_page()
运行效果如下:

在这个示例中,我们使用st.session_state.logged_in来存储用户的登录状态。
当用户在登录页面输入正确的用户名和密码后,st.session_state.logged_in被设置为True ,表示用户已经登录。
在主页面中,我们根据st.session_state.logged_in的值来决定显示的内容。
如果用户点击 “登出” 按钮,我们将st.session_state.logged_in设置为 False,并重新运行应用以更新登录状态。
3.2. 多页面应用中的数据共享
假设我们正在开发一个包含多个页面的Streamlit应用,用户在第一个页面中输入了一些数据,我们希望在第二个页面中使用这些数据进行进一步的处理。
import streamlit as st
# 初始化页面索引
if "page_index" not in st.session_state:
st.session_state.page_index = 0
# 页面1:数据输入
def page1():
st.title("页面1:数据输入")
st.session_state.user_input = st.text_input("请输入一些数据")
if st.button("下一步"):
st.session_state.page_index = 1
st.rerun()
# 页面2:数据处理
def page2():
st.title("页面2:数据处理")
st.write("你在页面1输入的数据是:", st.session_state.user_input)
if st.button("返回"):
st.session_state.page_index = 0
st.rerun()
# 根据页面索引显示相应的页面
if st.session_state.page_index == 0:
page1()
else:
page2()

在这个示例中,我们使用st.session_state.page_index来记录当前显示的页面索引。
在 页面1 中,用户输入的数据被存储在st.session_state.user_input中。
当用户点击 “下一步” 按钮时,我们将st.session_state.page_index设置为1,并重新运行应用以跳转到 页面2。
在页面2中,我们通过st.session_state.user_input获取用户在页面1中输入的数据,并进行处理。
如果用户点击 “返回” 按钮,我们将st.session_state.page_index设置为0,重新运行应用以返回 页面1。
4. 总结
通过以上两个示例,我们可以看到st.session_state在Streamlit应用中的强大功能。
它不仅可以保持用户输入的状态,还可以实现跨页面的状态共享和动态更新应用界面。
这些功能使得Streamlit应用能够更加灵活地响应用户的操作,提供更加丰富的交互体验。
不过,使用时,有些地方还是需要注意:
- 合理使用会话状态:虽然
st.session_state非常方便,但过度使用可能会导致应用的性能下降。因此,开发者需要合理地规划哪些数据需要存储在会话状态中,哪些数据可以通过其他方式传递。 - 注意数据的安全性:存储在
st.session_state中的数据可能会被用户通过浏览器的开发者工具访问到。因此,对于敏感数据(如密码等),开发者需要谨慎处理,避免直接存储在会话状态中。 - 避免状态冲突:在多用户同时使用应用的情况下,开发者需要注意避免会话状态之间的冲突。可以通过为每个用户分配唯一的会话标识符来解决这个问题。
- 清理无用状态:当用户完成操作或离开应用时,开发者可以清理
st.session_state中不再需要的状态信息,以节省资源。
总之,st.session_state是Streamlit应用中一个非常有用的工具,它为开发者提供了强大的会话管理功能。
通过合理地使用st.session_state,开发者可以构建出更加动态、交互式且用户友好的Streamlit应用。
『玩转Streamlit』--会话状态管理的更多相关文章
- Github 恶搞教程(一起『玩坏』自己的 Github 吧)
最近在伯乐在线读到一篇趣文,<如何在 Github『正确』做贡献>,里面各种能人恶搞 Github 的『Public contributions』,下面截取几个小伙伴的战绩: 顺藤摸瓜,发 ...
- 2017-2018-2 20155303『网络对抗技术』Exp6:信息收集与漏洞扫描
2017-2018-2 20155303『网络对抗技术』 Exp6:信息收集与漏洞扫描 --------CONTENTS-------- 一.原理与实践说明 1.实践内容 2.基础问题 二.实践过程记 ...
- 2018-2019-2 20165316 『网络对抗技术』Exp3:免杀原理与实践
2018-2019-2 20165316 『网络对抗技术』Exp3:免杀原理与实践 一 免杀原理与实践说明 (一).实验说明 任务一:正确使用msf编码器,msfvenom生成如jar之类的其他文件, ...
- 2017-2018-2 20155303『网络对抗技术』Final:Web渗透获取WebShell权限
2017-2018-2 『网络对抗技术』Final:Web渗透获取WebShell权限 --------CONTENTS-------- 一.Webshell原理 1.什么是WebShell 2.We ...
- # 2017-2018-2 20155319『网络对抗技术』Exp6:信息收集与漏洞扫描
2017-2018-2 20155319『网络对抗技术』Exp6:信息收集与漏洞扫描 实践内容 (1)各种搜索技巧的应用 (2)DNS IP注册信息的查询 (3)基本的扫描技术:主机发现.端口扫描.O ...
- 『编程题全队』Alpha 阶段冲刺博客Day1
『编程题全队』Alpha 阶段冲刺博客Day1 一.Alpha 阶段全组总任务 二.各个成员在 Alpha 阶段认领的任务 三.明日各个成员的任务安排 孙志威:实现基本的网络连接, 完成燃尽图模块 孙 ...
- 『Python基础-8』列表
『Python基础-8』列表 1. 列表的基本概念 列表让你能够在一个地方存储成组的信息,其中可以只包含几个 元素,也可以包含数百万个元素. 列表由一系列按特定顺序排列的元素组成.你可以创建包含字母表 ...
- 『Python基础-5』数字,运算,转换
『Python基础-5』数字,运算,转换 目录 基本的数字类型 二进制,八进制,十六进制 数字类型间的转换 数字运算 1. 数字类型 Python 数字数据类型用于存储数学上的值,比如整数.浮点数.复 ...
- 『Python基础-3』变量、定义变量、变量类型、关键字Python基础-3』变量、定义变量、变量类型、关键字
『Python基础-3』变量.定义变量.变量类型.关键字 目录: 1.Python变量.变量的命名 2.变量的类型(Python数据类型) 3.Python关键字 1. Python 变量.变量的命名 ...
- 『Python基础-1 』 编程语言Python的基础背景知识
#『Python基础-1 』 编程语言Python的基础背景知识 目录: 1.编程语言 1.1 什么是编程语言 1.2 编程语言的种类 1.3 常见的编程语言 1.4 编译型语言和解释型语言的对比 2 ...
随机推荐
- Blazor 组件库 BootstrapBlazor 中Circle组件介绍
组件介绍 Circle进度环组件,是一个图表类组件.一般有两种用途: 显示某项任务进度的百分比. 统计某些指标的占比. 它的样子如下: 它的代码如下: <Circle Width="2 ...
- Yacc笔记
语义动是一个C语句的序列 $$ 表是和相应产生式头的非终结符号关联的属性值 $i 表示和相应产生式体中第 i 个文法符号(终结符或非终结符号)关联的属性值 按照产生式规约时会执行关联的语义动作 对于 ...
- 一款基于 .NET MVC 框架开发、功能全面的MES系统
前言 今天大姚给大家分享一款基于 .NET MVC 框架开发.功能全面的离散型零部件制造管理系统(MES):EasyMES. 项目介绍 EasyMES一款基于 .NET 6 MVC 框架开发.开源免费 ...
- FineReport模板性能问题排查方法
1. 概述 模板的加载速度受到很多因素影响,如果一个模板预览的时候,加载较慢,该如何去分析问题原因呢? 2. 排查步骤 2.1 查看数据集查询速度 大部分模板加载慢,都是因为 sql 执行速度比较慢. ...
- 各种各样的 Host Builder
各种各样的 Host Buider If you're building for the web or writing a distributed application, you might nee ...
- 【Javaweb】【Maven】Use IDEA and Maven create a Java Web Application
Open This Url :https://mvnrepository.com/ Search Servlet Select the latest version Copy it! Paste An ...
- Qt采集本地摄像头推流成rtsp/rtmp(可网页播放/支持嵌入式linux)
一.功能特点 支持各种本地视频文件和网络视频文件. 支持各种网络视频流,网络摄像头,协议包括rtsp.rtmp.http. 支持将本地摄像头设备推流,可指定分辨率和帧率等. 支持将本地桌面推流,可指定 ...
- UML之包与包图
了解UML的人都知道UML中也有包的概念,包在UML中作用与面向对象编程语言中类似,它是管理对象的工具,也是解决对象同名冲突的手段. 在UML中,包的表示图形是一个左上角带标签的矩形,而包名可以标注于 ...
- opencv中 在特征点匹配代码举例,以及queryIdx和trainIdx的用法
一.用法 在特征点匹配中,queryIdx和trainIdx是匹配对中的两个索引,用于指示匹配点在不同图像或特征向量中的位置.1.假设我们有两幅图像A和B,并使用特征点提取算法(如SIFT)从它们中提 ...
- [转]升级/重装win10系统--提示无法验证密钥的解决办法
在由win7系统升级到win10时,出现了无法验证密钥的问题(还未提示输入密钥的时候就直接提示无法验证密钥),英文版报错为:Windows 10 setup has failed to validat ...