還記得上篇文章我們采用Plotly去畫出各式各樣的圖,這次我們就來講講,如何把這些圖片展示在你的前端上。
Dash也是Plotly制作團(tuán)隊(duì)開源出來的一款dashboard開發(fā)平臺(tái),主要使用python寫的,它主要可以將我們畫出來的數(shù)據(jù)展示在網(wǎng)頁上。Dash最大的優(yōu)點(diǎn)就是你在生成前端的時(shí)候不需要寫任何javascript代碼(已經(jīng)全在底層封裝好,畫圖特效是react.js寫的,有興趣可以去研究一下源碼),它可以直接使用Python代碼將你之前在Plotly畫出的圖在網(wǎng)頁上直接展示出來。
需要安裝的庫:
pip install plotly
pip install dash
下面我們來演示一個(gè)Dash的demo:
新建一個(gè)app.py文件,復(fù)制以下代碼:
import dash
import dash_core_components as dcc
import dash_html_components as html
external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']
app = dash.Dash(__name__, external_stylesheets=external_stylesheets)
app.layout = html.Div(children=[
html.H1(children='Dash Demo', style={"text-align": "center"}),
html.Div(children='''
一款牛逼的Python開發(fā)的應(yīng)用程序---------Dash
''',
style={"text-align": "center", "color": "red"}),
dcc.Graph(
id='example-graph',
figure={
'data': [
{'x': [1, 2, 3], 'y': [3, 4, 2], 'type': 'bar', 'name': '數(shù)據(jù)源A'},
{'x': [1, 2, 3], 'y': [2, 3, 5], 'type': 'bar', 'name': '數(shù)據(jù)源B'},
],
'layout': {
'title': '數(shù)據(jù)展示'
}
}
)
])
if __name__ == '__main__':
app.run_server(debug=True)
運(yùn)行效果:
下面來說明一下,如何去使用Dash這個(gè)框架:
S1: 初始化
app = dash.Dash(__name__, external_stylesheets=external_stylesheets)
這句話主要用來初始化渲染Dash,可以按照你制定的樣式進(jìn)行渲染。
external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']
代碼中引用的網(wǎng)址是plotly自己的css樣式,你也可以修改成你自己想要的其他樣式,把這個(gè)css文件down到本地然后你可以對(duì)他進(jìn)行修改。具體參考:
https://dash.plotly.com/external-resources
下面重點(diǎn)來了!
在頁面上添加你想要添加的元素,首先我們需要初始化頁面的布局:
app.layout = html.Div(children=[])
初始化完畢后我們就可以向這個(gè)布局中添加元素了,我們只需要在childern這個(gè)list中添加相應(yīng)的頁面元素即可:(注意:每個(gè)元素都在list中)
****S2: 添加標(biāo)簽
添加h1標(biāo)題
html.H1(children='Dash Demo', style={"text-align": "center"}),
添加一個(gè)div
html.Div(children='一款牛逼的Python開發(fā)的應(yīng)用程序---------Dash',
style={"text-align": "center", "color": "red"}),
我們可以在里面添加style參數(shù)來制定它的樣式。
****S3: 添加你畫的圖
Graph對(duì)象主要就是用來進(jìn)行畫圖的,你只需要將畫圖的數(shù)據(jù)傳遞給figure參數(shù)即可。
dcc.Graph(
id='example-graph',
figure={
'data': [
{'x': [1, 2, 3], 'y': [3, 4, 2], 'type': 'bar', 'name': '數(shù)據(jù)源A'},
{'x': [1, 2, 3], 'y': [2, 3, 5], 'type': 'bar', 'name': '數(shù)據(jù)源B'},
],
'layout': {
'title': '數(shù)據(jù)展示'
}
}
)
這里說一下,plotly畫出的每個(gè)對(duì)象都能直接當(dāng)成參數(shù)傳入。
我們看一個(gè)例子:選擇我們上次畫等高線圖,直接插入畫好的fig對(duì)象。
import plotly.graph_objects as go
fig = go.Figure(data=
go.Contour(
z=[[10, 10.625, 12.5, 15.625, 20],
[5.625, 6.25, 8.125, 11.25, 15.625],
[2.5, 3.125, 5., 8.125, 12.5],
[0.625, 1.25, 3.125, 6.25, 10.625],
[0, 0.625, 2.5, 5.625, 10]]
))
......... dcc.Graph( id='example-graph',
figure=fig
)
添加多個(gè)圖:
****S4: 添加常見的網(wǎng)頁控件
輸入框:
dcc.Input(id='my-id',
value='2333',
type='text'
),
下拉框:
dcc.Dropdown(
options=[
{'label': 'New York City', 'value': 'NYC'},
{'label': 'Montréal', 'value': 'MTL'},
{'label': 'San Francisco', 'value': 'SF'}
],
value='MTL'
),
滑動(dòng)條:
dcc.Slider(
min=0,
max=9,
marks={i: 'level{}'.format(i) for i in range(10)},
value=5,
),
復(fù)選框:
dcc.Checklist(
options=[
{'label': 'New York City', 'value': 'NYC'},
{'label': 'Montréal', 'value': 'MTL'},
{'label': 'San Francisco', 'value': 'SF'}
],
values=['MTL', 'SF']
)
MarkDown格式:
dcc.Markdown('''
Dash and Markdown
Dash supports [Markdown](http://commonmark.org/help).
Markdown is a simple way to write and format text.
It includes a syntax for things like **bold text** and *italics*,
[links](http://commonmark.org/help), inline `code` snippets, lists,
quotes, and more.
''')
****S5: 啟動(dòng)你的應(yīng)用
if __name__ == '__main__':
app.run_server(debug=True)
debug在調(diào)試的時(shí)候可以打開,部署在生產(chǎn)環(huán)境的時(shí)候記得改成Fasle,還有個(gè)參數(shù)use_reloader,如果你是在jupyter寫代碼,該參數(shù)需要設(shè)置成False。
-
數(shù)據(jù)
+關(guān)注
關(guān)注
8文章
7006瀏覽量
88950 -
可視化
+關(guān)注
關(guān)注
1文章
1194瀏覽量
20936 -
python
+關(guān)注
關(guān)注
56文章
4793瀏覽量
84632 -
DASH
+關(guān)注
關(guān)注
0文章
8瀏覽量
2687
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論