50行Python代码绘制数据大屏,这个可视化框架真的太神了
The following article is from 关于数据分析与可视化 Author 俊欣
Python
框架,名叫Dash
,建立在Flask
、Plotly.js
以及React.js
的基础之上,在创建之出的目的是为了帮助前端知识匮乏的数据分析人员,以纯Python
编程的方式快速制作出交互特性强的数据可视化大屏,在经过多年的迭代发展,如今不仅仅可以用来开发在线数据可视化作品,即便是轻量级的数据仪表盘、BI应用甚至是博客或者是常规的网站都随处可见Dash
框架的影子,今天小编就先来介绍一下该框架的一些基础知识,并且来制作一个简单的数据可视化大屏。Dash框架中的两个基本概念
Dash
框架中的两个基本概念Layout Callbacks
Layout
顾名思义就是用来设计可视化大屏的外观和布局,添加一些例如下拉框、单选框、复选框、输入框、文本框、滑动条等组件,其中Dash
框架对HTML
标签也进行了进一步的封装,使得我们直接可以通过Python
代码来生成和设计每一个网页所需要的元素,例如<div>
<h1>Hello World!!</h1>
<div>
<p>Dash converts Python classes into HTML</p>
</div>
</div>
我们转化成Dash
的Python
结构就是
html.Div([
html.H1('Hello Dash'),
html.Div([
html.P('Dash converts Python classes into HTML'),
])
])
Callbacks
也就是回调函数,基本上是以装饰器的形式来体现的,实现前后端异步通信的交互,例如我们在点击按钮或者下拉框之后出现的功能就是通过回调函数来实现的。安装和导入模块
在导入模块之前,我们先用pip命令来进行安装,
! pip install dash
! pip install dash-html-components
! pip install dash-core-components
! pip install plotly
dash-html-components
用来生成HTML
标签,dash-core-components
模块用来生成例如下拉框、输入框等组件,这里我们还需要用到plotly
模块,因为我们需要用到的数据来自该模块,里面是一众互联网公司过去一段时间中股价的走势import dash
import dash_html_components as html
import dash_core_components as dcc
import plotly.graph_objects as go
import plotly.express as px
读取数据并且绘制折线图
那么我们读取数据并且用plotly
来绘制折线图,代码如下
app = dash.Dash() #实例化Dash
df = px.data.stocks() #读取股票数据
def stock_prices():
# 绘制折线图
fig = go.Figure([go.Scatter(x=df['date'], y=df['AAPL'],
line=dict(color='firebrick', width=4), name='Apple')
])
fig.update_layout(title='股价随着时间的变幻',
xaxis_title='日期',
yaxis_title='价格'
)
return fig
app.layout = html.Div(id='parent', children=[
html.H1(id='H1', children='Dash 案例一', style={'textAlign': 'center',
'marginTop': 40, 'marginBottom': 40}),
dcc.Graph(id='line_plot', figure=stock_prices())
])
if __name__ == '__main__':
app.run_server()
从代码的逻辑上来看,我们通过Dash
框架中的Div
方法来进行页面的布局,其中有参数id
来指定网页中的元素,以及style
参数来进行样式的设计,最后我们将会指出来的图表放在dcc.Graph()
函数当中。
添置一个下拉框
然后我们再添置一个下拉框,当我们点击这个下拉框的时候,可是根据我们的选择展示不同公司的股价,代码如下
dcc.Dropdown(id='dropdown',
options=[
{'label': '谷歌', 'value': 'GOOG'},
{'label': '苹果', 'value': 'AAPL'},
{'label': '亚马逊', 'value': 'AMZN'},
],
value='GOOG'),
output
options
参数中的label
对应的是下拉框中的各个标签,而value
对应的是DataFrame
当中的列名
df.head()
output
添加回调函数
@app.callback(Output(component_id='bar_plot', component_property='figure'),
[Input(component_id='dropdown', component_property='value')])
def graph_update(dropdown_value):
print(dropdown_value)
# Function for creating line chart showing Google stock prices over time
fig = go.Figure([go.Scatter(x=df['date'], y=df['{}'.format(dropdown_value)],
line=dict(color='firebrick', width=4))
])
fig.update_layout(title='股价随着时间的变幻',
xaxis_title='日期',
yaxis_title='价格'
)
return fig
callback()
方法中指定输入和输出的媒介,其中Input
参数,里面的component_id
对应的是下拉框的id
也就是dropdown
,而Output
参数,当中的component_id
对应的是折线图的id
也就是bar_plot
,我们来看一下最后出来的结果如下最后,全部的代码如下所示
import dash_html_components as html
import dash_core_components as dcc
import plotly.graph_objects as go
import plotly.express as px
from dash.dependencies import Input, Output
app = dash.Dash()
df = px.data.stocks()
app.layout = html.Div(id='parent', children=[
html.H1(id='H1', children='Dash 案例一', style={'textAlign': 'center',
'marginTop': 40, 'marginBottom': 40}),
dcc.Dropdown(id='dropdown',
options=[
{'label': '谷歌', 'value': 'GOOG'},
{'label': '苹果', 'value': 'AAPL'},
{'label': '亚马逊', 'value': 'AMZN'},
],
value='GOOG'),
dcc.Graph(id='bar_plot'),
])
@app.callback(Output(component_id='bar_plot', component_property='figure'),
[Input(component_id='dropdown', component_property='value')])
def graph_update(dropdown_value):
print(dropdown_value)
fig = go.Figure([go.Scatter(x=df['date'], y=df['{}'.format(dropdown_value)],
line=dict(color='firebrick', width=4))
])
fig.update_layout(title='股价随着时间的变幻',
xaxis_title='日期',
yaxis_title='价格'
)
return fig
if __name__ == '__main__':
app.run_server()
<END>
程序员专属T恤
推荐阅读: