当前位置:网站首页>【干货原创】发现了一个好用到爆的数据分析利器
【干货原创】发现了一个好用到爆的数据分析利器
2022-07-22 21:34:00 【欣一2002】
小编最近碰上了一个数据分析利器,可以将我们需要的数据展示在网页上,并且进行相对深度的数据分析与挖掘,所以就打算借此机会和大家分享一下。
关于streamlit-aggrid
我们知道用Streamlit模块来进行web应用的开发真的非常的方便,但是在展示表格方面则显得十分地简陋,只有两个简单的接口函数,分别是st.table(df)和st.dataframe(df),对于字段较多的表格数据的展示非常的不友好,今天小编就来介绍一款Streamlit的插件,streamlit-aggrid,它的基础功能包括
数据排序
表格样式的调整
数据的筛选
翻页
等等
首先我们先通过pip命令下载该模块
pip install streamlit-aggrid我们先来写一个简单的demo,看一下该模块到底能实现哪些功能,代码如下
import pandas as pd
import streamlit as st
from st_aggrid import AgGrid
st.set_page_config(page_title="网飞(Netflix)的电影数据分析", layout="wide")
st.title("网飞(Netflix)的电影数据分析")
shows = pd.read_csv("netflix_titles.csv")
AgGrid(shows)output

我们和st.dataframe(shows)出来的结果相比,发现调用streamlit-aggrid模块展示出来的表格更加美观,如下图所示
不同方法的结果对比


当然我们还能够给数据进行排序,如下图所示

并且还可以根据指定的条件来进行数据的筛选,如下图所示

我们还可以按照自己的喜好来拖拽表格当中的每一列的数据,调整表格的顺序

更多操作
翻页
除了上面的一些基本操作之外,streamlit-aggrid模块展示出来的表格数据还支持翻页操作,代码如下
import pandas as pd
import streamlit as st
from st_aggrid import AgGrid
from st_aggrid.grid_options_builder import GridOptionsBuilder
st.set_page_config(page_title="网飞(Netflix)的电影数据分析", layout="wide")
st.title("网飞(Netflix)的电影数据分析")
shows = pd.read_csv("netflix_titles.csv")
gb = GridOptionsBuilder.from_dataframe(shows)
gb.configure_pagination()
gridOptions = gb.build()
AgGrid(shows, gridOptions=gridOptions)output

分组统计
我们平常在Pandas模块当中用到的groupby分组统计来streamlit-aggrid模块当中也可以轻松地实现,代码如下
import pandas as pd
import streamlit as st
from st_aggrid import AgGrid
from st_aggrid.grid_options_builder import GridOptionsBuilder
st.set_page_config(page_title="网飞(Netflix)的电影数据分析", layout="wide")
st.title("网飞(Netflix)的电影数据分析")
shows = pd.read_csv("netflix_titles.csv")
gb = GridOptionsBuilder.from_dataframe(shows)
gb.configure_pagination()
gb.configure_side_bar()
gb.configure_default_column(groupable=True, value=True, enableRowGroup=True, aggFunc="sum", editable=True)
gridOptions = gb.build()
AgGrid(shows, gridOptions=gridOptions, enable_enterprise_modules=True)这样,在表格的最左侧会出现工具栏,我们可以在其中进行进一步的操作,如下图所示

高亮表格数据
在Pandas模块当中我们可以给指定的数据高亮显示,那么同样地在streamlit-aggrid模块当中也可以实现,代码如下
shows = pd.read_csv("netflix_titles.csv")
gb = GridOptionsBuilder.from_dataframe(shows)
cellsytle_jscode = JsCode(
"""
function(params) {
if (params.value.includes('United States')) {
return {
'color': 'white',
'backgroundColor': 'red'
}
} else {
return {
'color': 'black',
'backgroundColor': 'white'
}
}
};
"""
)
gb.configure_column("country", cellStyle=cellsytle_jscode)
gridOptions = gb.build()
data = AgGrid(
shows,
gridOptions=gridOptions,
enable_enterprise_modules=True,
allow_unsafe_jscode=True
)我们将国家为“美国”的电影数据用红色高亮显示出来,如下图所示

数据集的获取链接是:https://www.kaggle.com/datasets/shivamb/netflix-shows?resource=download
NO.1
往期推荐
Historical articles
用Python制作可视化GUI界面,一键实现多种风格的照片处理
分享、收藏、点赞、在看安排一下?




边栏推荐
- 局域网SDN技术硬核内幕 - 16 三 从物到人 园区用户漫游的EVPN实现
- Wechat hotel reservation applet graduation project (5) assignment
- 如何优雅的改变this指向
- Mysql的索引为什么用B+树而不是跳表?
- Scala generic generic class details - t
- 船舶测试/ IMO A.799 (19)船用结构材料不燃性试验
- 网络安全之ARP欺骗防护
- 开幕在即 | “万物互联,使能千行百业”2022开放原子全球开源峰会OpenAtom OpenHarmony分论坛
- ETL tool (data synchronization)
- Wechat campus second-hand book trading applet graduation design finished product (8) graduation design thesis template
猜你喜欢
随机推荐
1.10 API 和字符串
基于ROS的导航框架
自定义flink es source
局域网SDN技术硬核内幕 6 分布式任意播网关
Squid proxy service +ip proxy pool
類和對象(1)
Here comes the genuine Adobe software! Adobe's only genuine family bucket subscription in the world costs only 0 yuan / year
Implementation of remove function
Classes and objects (1)
6-15漏洞利用-smb-RCE远程命令执行
URL的结构解读
主题域模型
Wechat hotel reservation applet graduation project (6) opening defense ppt
不会吧?钉钉都下载了,你还不知道可以这样玩?
VScode配置用户代码片段
Wechat hotel reservation applet graduation project (5) assignment
Scala Generic 泛型类详解 - T
About redis, do you update the database first or the cache first?
沃尔沃xc90的安全性如何?一起来看看吧
Scala学习——泛型[T]的6种使用









