首页 > 其他分享 >『玩转Streamlit』--集成Matplotlib

『玩转Streamlit』--集成Matplotlib

时间:2024-12-17 22:34:52浏览次数:3  
标签:-- Matplotlib st import ax Streamlit data

Steamlit虽然也自带了一些绘图组件(比如折线图,柱状图和散点图等等),但是都比较简单,

Python传统的可视化库比起来,功能上差了很多。

本篇介绍如何在Streamlit App中使用Matplotlib库来绘图。

1. st.pyplot函数

st.pyplot函数专门用于在Steamlit应用中显示 Matplotlib 绘制的图形。

这个函数能够直接将Matplotlib Figure对象直接渲染到页面的指定位置上。

st.pyplot的参数不多,主要有:

名称 类型 说明
fig Figure对象 要渲染的 Matplotlib Figure 对象
clear_figure bool 控制图形渲染后是否清除
use_container_width bool 决定是否使用父容器的宽度覆盖图形的原始宽度

最重要的就是fig参数,它是通过 Matplotlib 的常规绘图方式创建图形对象。

也就是说,我们绘制图形时,完全不用考虑Streamlit,正常使用Matplotlib来绘图,

绘制之后直接将Matplotlibfig对象传给st.pyplot函数即可。

2. Matplotlib兼容性问题

在使用 MatplotlibStreamlit 结合时,可能会遇到一些兼容性问题。

Matplotlib 支持多种 Backend,如果在使用过程中出现错误,可以尝试将Backend设置为TkAgg

具体的设置方法如下:

  1. 打开~/.matplotlib/matplotlibrc文件,如果不存在就创建一个
  2. 在上面的文件中添加一行:backend: TkAgg

如果是windows系统,上面的文件路径改为:C:\Users\%username%\.matplotlib\matplotlibrc

此外,Matplotlib 在多线程环境下可能会出现问题,因为它本身对线程的支持并不完善。

当部署和共享应用程序时,由于可能存在并发用户,这个问题可能会更加突出。

为了解决这个问题,建议使用RendererAgg.lock来包裹 Matplotlib 相关代码,如下所示:

from matplotlib.backends.backend_agg import RendererAgg
_lock = RendererAgg.lock

with _lock:
    fig.title('sample figure')
    fig.plot([1,20,3,50])
    st.pyplot(fig)

3. 使用示例

下面通过两个根据实际情况简化的示例来演示两者结合的效果。

3.1. 模拟数据分析项目

这个示例中,我们使用 np.random 函数生成了包含三列不同类型随机数据的 DataFrame

在数据分析与可视化部分,根据选择的列进行不同类型的绘图操作,

  • 当选择 Column1Column2 时绘制柱状图或直方图
  • 当选择 Column3 时可选择绘制 Column1Column2 的散点图

本示例主要展示了 StreamlitMatplotlib 结合在数据探索和分析可视化方面的便利性与交互性。

import streamlit as st
import pandas as pd
import matplotlib.pyplot as plt
import seaborn as sns
import numpy as np

import matplotlib

# 为了显示中文
matplotlib.rcParams["font.sans-serif"] = ["Microsoft YaHei Mono"]
matplotlib.rcParams["axes.unicode_minus"] = False


# 生成随机数据
@st.cache_data
def generate_data():
    # 生成 100 行 3 列的随机数据
    data = {
        "Column1": np.random.randint(1, 100, 100),
        "Column2": np.random.normal(50, 10, 100),
        "Column3": np.random.choice(["A", "B", "C"], 100),
    }
    return pd.DataFrame(data)


data = generate_data()

# 数据探索部分
st.subheader("数据探索")
st.write(data.head())

# 数据分析与可视化
st.subheader("数据分析与可视化")
# 选择分析的列
selected_column = st.selectbox("选择要分析的列", data.columns)

# 使用 Matplotlib 绘制柱状图
if selected_column in ["Column1", "Column2"]:
    fig, ax = plt.subplots()
    if selected_column == "Column1":
        sns.countplot(data=data, x=selected_column, ax=ax)
    else:
        sns.histplot(data=data, x=selected_column, kde=True, ax=ax)
    ax.set_title(f"{selected_column} 分布情况")
    ax.set_xlabel(selected_column)
    ax.set_ylabel("数量")
    st.pyplot(fig)

# 绘制散点图(以 Column1 和 Column2 为例)
elif selected_column == "Column3":
    if st.checkbox("显示散点图"):
        fig2, ax2 = plt.subplots()
        ax2.scatter(data["Column1"], data["Column2"])
        ax2.set_title("Column1 与 Column2 的关系")
        ax2.set_xlabel("Column1")
        ax2.set_ylabel("Column2")
        st.pyplot(fig2)

运行效果:

3.2. 模拟数据监控与报告

在这个数据监控与报告应用示例中,通过get_live_data 函数模拟获取实时数据(实际应用中可替换为真实的数据获取逻辑)。

然后通过一个循环,不断获取新数据并合并到总的数据集中,再使用 Matplotlib 绘制折线图展示数据随时间的变化趋势。

这样就构建了一个简单的实时数据监控应用,在实际业务场景中,例如监控服务器性能指标、生产线上的关键数据等,可以让相关人员实时直观地了解数据的变化情况,及时发现异常并做出决策。

import streamlit as st
import matplotlib.pyplot as plt
import time
import random
import pandas as pd

import matplotlib

# 为了显示中文
matplotlib.rcParams["font.sans-serif"] = ["Microsoft YaHei Mono"]
matplotlib.rcParams["axes.unicode_minus"] = False


# 模拟获取实时数据的函数
def get_live_data():
    # 这里可以替换为真实的获取数据逻辑,比如从数据库或 API 获取
    new_data = pd.DataFrame(
        {
            "time": [time.strftime("%H:%M:%S")],
            "value": [random.randint(-10, 10)],
        }
    )
    return new_data


# 初始化数据
data = pd.DataFrame(columns=["time", "value"])

# 实时数据监控应用标题
st.title("实时数据监控")

# 创建一个占位符用于更新图表
chart_placeholder = st.empty()

while True:
    # 获取新数据
    new_data = get_live_data()
    # 合并新数据到总数据
    data = pd.concat([data, new_data], ignore_index=True)

    # 使用 Matplotlib 绘制折线图
    fig, ax = plt.subplots()
    ax.plot(data["time"], data["value"])
    ax.set_title("实时数据趋势")
    ax.set_xlabel("时间")
    ax.set_ylabel("数值")
    ax.set_xticklabels(data["time"], rotation=45)

    # 在 Streamlit 中更新图表
    chart_placeholder.pyplot(fig)

    # 每隔一段时间更新数据(这里设置为 2 秒)
    time.sleep(2)

运行效果:

4. 总结

StreamlitMatplotlib 结合的关键点在于,Streamlit 提供便捷的应用构建框架,Matplotlib 专注强大的绘图功能,二者通过 st.pyplot 函数紧密相连。

在数据处理流程上,可先在 Matplotlib 中依据数据特性灵活创建各类图形对象,再借助 Streamlit 整合进应用。

它们结合的优势也非常明显,首先,在可视化效率方面,能快速将 Matplotlib 绘制的图形嵌入 Streamlit 应用,减少开发时间与代码量。

其次,在交互性上,Streamlit 的丰富交互组件可与 Matplotlib 图形联动,如通过按钮、滑块等控制图形展示内容或范围,让用户更方便的进行数据探索。

标签:--,Matplotlib,st,import,ax,Streamlit,data
From: https://www.cnblogs.com/wang_yb/p/18613506

相关文章

  • MSKSSRV.SYS 是一个系统文件,通常与 Microsoft Kernel-Streaming 服务相关。它是 Windo
    MSKSSRV.SYS是一个系统文件,通常与MicrosoftKernel-Streaming服务相关。它是Windows操作系统中的一个驱动程序文件,主要用于处理音频、视频流媒体的传输与处理,尤其是涉及到多媒体设备时的音频和视频流控制。详细解释:文件名称: MSKSSRV.SYS文件类型: 驱动程序文件位置: 通......
  • 一文读懂TypeC 耳机原理
    一、名词解释SOURCE:提供VBUS电源的设备SINK:从VBUS取电的设备DFP(DownstreamFacingPort):下行端口,可以理解为Host,DFP提供VBUS。UFP(UpstreamFacingPort):上行端口,可以理解为Device,UFP从VBUS中取电。典型设备是U盘,移动硬盘。DRP(DualRolePort):双角色端口,DRP既可以......
  • 混合乱用模式之《观察者模式》AND《责任链模式》
    有时候面对复杂的场景,就想着怎么解耦、怎么复用、怎么扩展,然后无意间各种设计模式就拧巴在一起了。责任链和观察者的区别责任链强调的是顺序,前后可能有逻辑关系。而观察者体现的是的独立性。虽然都有传递消息通知执行的功能,但是侧重点不同。两个结合使用我的这个业务场景正......
  • 四大跨平台开发框架深度解析——uniapp、uniapp-X、React Native与Flutter
    引言随着移动互联网的飞速发展,跨平台开发框架成为了开发者们关注的焦点。这些框架旨在通过编写一套代码,实现多个平台的应用开发,从而大幅提高开发效率和降低维护成本。本文将深入剖析uniapp、uniapp-X、ReactNative和Flutter这四个主流的跨平台开发框架,探讨它们的优缺点及......
  • [蓝桥杯 2021 省 AB2] 国际象棋
    题目Description众所周知,“八皇后”问题是求解在国际象棋棋盘上摆放 8 个皇后,使得两两之间互不攻击的方案数。已经学习了很多算法的小蓝觉得“八皇后”问题太简单了,意犹末尽。作为一个国际象棋迷,他想研究在 N×M 的棋盘上,摆放 K 个马,使得两两之间互不攻击有多少种摆......
  • AI到底有多厉害:探索人工智能的无限可能
    在科技日新月异的今天,人工智能(AI)已经成为了一个无处不在的话题。从智能家居到自动驾驶汽车,从医疗诊断到金融分析,AI正以其惊人的速度和广度,渗透到我们生活的方方面面。那么,AI到底有多厉害?它究竟能为我们带来哪些改变?让我们一同探索这个充满无限可能的世界。一、AI在医疗领域的......
  • Linux 学习详细指南
    文章目录Linux学习详细指南1.基础知识准备计算机硬件与软件网络基础编程语言2.安装Linux发行版选择安装方式3.熟悉用户界面GUICLI4.学习基本命令文件系统命令用户与权限进程管理软件包管理5.深入学习Shell脚本编程系统管理安全性性能优化6.实践应用项目实践......
  • 全平台局域网(内网)数据传输工具 LoadSend
    前言不同系统的电脑、手机,文件传输有没有简单一点的方法?手机是iPhone,电脑是Windows,如何更快捷传输文件呢?我们最常用和用得最多的文件传输工具可能就是微信以及QQ了吧!其实,如果只是在局域网内,用微信这一类聊天工具来传输文件并不算特别合适,除了可能存在的文件大小限制,最大的问......
  • 鸿蒙项目云捐助第十一讲鸿蒙App应用的捐助成功自定义对话框组件实现
    在生活中,用户做了一个好事后,很多场合都会收到一份感谢。在捐助的行业也是一样的,用户捐出了一片爱心,就会收获一份温情。这里的温情是通过自定义对话框实现的。一、通过自定义对话框组件实现捐款成功的信息页这里用户捐款成功或者捐赠物品成功,相当于用户获得一份爱心的回馈。这......
  • 求最大公约数
    方法一:#include<stdio.h>intmain(){   inta,b;   scanf("%d%d",&a,&b);   inti,max,min;   max=0;  min=(a<b)?a:b;   for(i=1;i<=min;i++)   {      if(a%i==0&&b%i==0)         max=i;   }   prin......