前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >干货分享 | 用 Streamlit 来制作数据可视化面板教程(一)

干货分享 | 用 Streamlit 来制作数据可视化面板教程(一)

作者头像
用户6888863
发布2021-07-19 14:09:47
3.3K0
发布2021-07-19 14:09:47
举报
文章被收录于专栏:AI篮球与生活

对于数据分析师,建模工程师来说,将处理好的数据放在可视化的面板上进行呈现将更加有助于同事、领导来理解结果,今天小编就给大家来介绍一下如何用Python来制作一个数据可视化面板,使用的是Streamlit库,对于开发人员来说,只需几分钟就可以构建和部署强大的数据应用程序。

01

准备工作

使用“pip”安装并运行“hello world”应用

代码语言:javascript
复制
pip install streamlit
streamlit hello

接下来的几秒钟内,示例应用将在默认浏览器中打开,表明“streamlit”模块已经在本机安装成功了

02

添加文本数据

首先我们先来往里面添加一些文本数据,“streamlit”模块当中有不少的API来实现上述的目的,例如

代码语言:javascript
复制
st.title("This is title")
st.header('This is a header')
st.subheader('This is a subheader')
st.markdown('Streamlit is **_really_ cool**.')

除此之外,我们还可以使用特定的方法来往页面当中写入文本数据,例如

代码语言:javascript
复制
st.write("Hello World!!")

03

添加数据框

除了可以往页面当中添加文本内容之外,表格内容也可以通过“st.write()”方法来往页面中插入,当然“st.write()”这个方法也是十分的万能,这个我们后面再详细叙说

代码语言:javascript
复制
st.write("Here's our first attempt at using data to create a table:")
st.write(pd.DataFrame({
    'first column': [1, 3, 5, 7],
    'second column': [10, 30, 50, 70]
}))

当然我们其实无需调用任何“streamlit”的方法来展示数据,它支持“魔法命令”,只需少量的键盘操作就可以将markdown文本和表格数据写入应用,示例如下

代码语言:javascript
复制
"""
# My first app
Here's our first attempt at using data to create a table:
"""
df = pd.DataFrame({
  'first column': [1, 5, 2, 6],
  'second column': [40, 50, 60, 70]
})
df

04

折线图的可视化

“streamlit”中的“line_chart”显示折线图,方法原型

代码语言:javascript
复制
streamlit.line_chart(data=None, width=0, height=0)

参数:

  • data:要绘制的数据,可以是如下类型:
    • pandas.DataFrame
    • pandas.Styler
    • numpy.ndarray
    • Iterable
    • dict – None
  • width:图表宽度像素数,0表示使用默认宽度
  • height:图表高度像素数,0表示使用默认高度

例如下面的代码

代码语言:javascript
复制
chart_data = pd.DataFrame(
    np.random.randn(50, 3),
    columns=['a', 'b', 'c'])

st.line_chart(chart_data)

05

区域图的可视化

“streamlit”中的“area_chart”方法显示区域图,方法原型和折线图用到的方法一致,所以这里就不做过多的赘述,例如下面的代码

代码语言:javascript
复制
chart_data = pd.DataFrame(
    np.random.randn(50, 3),
    columns=['a', 'b', 'c'])

st.area_chart(chart_data)

06

柱状图的可视化

“streamlit”的“bar_chart()”方法显示柱状图,例如下面的代码

代码语言:javascript
复制
chart_data = pd.DataFrame(np.random.randn(50, 3),
                          columns=['a', 'b', 'c'])
st.bar_chart(chart_data)

07

地图的可视化

使用“st.map()”方法可以在地图上显示数据点,我们先生成一些随机的示例数据,并在旧金山的地图上进行可视化

代码语言:javascript
复制
map_data = pd.DataFrame(
    np.random.randn(1000, 2) / [50, 50] + [37.76, -122.4],
    columns=['latitude', 'longitude'])
st.map(map_data)

08

显示图像

“streamlit”中的“image”方法可以用来显示一张或多张图像,其中的方法原型,

代码语言:javascript
复制
streamlit.image(image, caption=None, width=None, use_column_width=False, clamp=False, channels='RGB', format='JPEG')

参数:

  • image:要显示的图像,类型可以是numpy.ndarray, [numpy.ndarray], BytesIO, str, 或 [str]) – 单色图像为(w,h) 或 (w,h,1)
    • 彩色图像为(w,h,3)
    • RGBA图像为(w,h,4)
    • 也可以指定一个图像url,或url列表
  • caption:图像标题,字符串。如果显示多幅图像,caption应当是字符串列表
  • width :图像宽度,None表示使用图像自身宽度
  • use_column_width:如果设置为True,则使用列宽作为图像宽度
  • clamp:是否将图像的像素值压缩到有效域(0~255) ,仅对字节数组图像有效。
  • channels:图像通道类型,'RGB' 或 'BGR',默认值:RGB
  • format:图像格式:'JPEG' 或'PNG'),默认值:JPEG

例如下面的代码

代码语言:javascript
复制
image = Image.open('1.jpg')
st.image(image, caption='法国普罗旺斯薰衣草', use_column_width=True)
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-06-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 关于数据分析与可视化 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档