Python的Web可視化框架Dash(5)---狀態(tài)和預(yù)更新

【Dash系列】Python的Web可視化框架Dash(1)---簡介
【Dash系列】Python的Web可視化框架Dash(2)---安裝
【Dash系列】Python的Web可視化框架Dash(3)---布局設(shè)置
【Dash系列】Python的Web可視化框架Dash(4)---基本回調(diào)
【Dash系列】Python的Web可視化框架Dash(5)---狀態(tài)和預(yù)更新
【Dash系列】Python的Web可視化框架Dash(6)---交互和過濾
【Dash系列】Python的Web可視化框架Dash(7)---回調(diào)共享
【Dash系列】Python的Web可視化框架Dash(8)---核心組件

本節(jié)介紹如何實現(xiàn)Dash應(yīng)用的回調(diào)先導(dǎo)入本節(jié)用到的所有包
import pandas as pd
import plotly.graph_objs as go
import dash
import dash_core_components as dcc                  # 交互式組件
import dash_html_components as html                 # 代碼轉(zhuǎn)html
from dash.dependencies import Input, Output         # 回調(diào)
from jupyter_plotly_dash import JupyterDash         # Jupyter中的Dash


一、基本回調(diào)

(一) 代碼

app = JupyterDash('State_id', height = 50)

app.layout = html.Div([
    dcc.Input(id = 'input-01', type = 'text', value = '中國'),
    dcc.Input(id = 'input-02', type = 'text', value = '北京'),
    html.Div(id = 'input-many')
])

@app.callback(Output('input-many', 'children'),
              [Input('input-01', 'value'), Input('input-02', 'value')])
def update_input(input01, input02):
    return f"""第一個輸入項{input01},第二個輸入項{input02}"""
app

(二)效果圖

(三)說明

  1. 本例中,當(dāng)輸入框中輸入的值發(fā)生變化時铅忿,對應(yīng)的文字顯示會同步變化;
  2. dash.dependencies.Input的屬性變化,會激活回調(diào)函數(shù)斑唬,進(jìn)行數(shù)據(jù)更新,如效果圖黎泣;

二恕刘、State回調(diào)

(一) 代碼

# 設(shè)置Dash
app = JupyterDash('State_id', height = 60)
app.layout = html.Div([
    dcc.Input(id = 'input01-state', type = 'text', value = '中國'),
    dcc.Input(id = 'input02-state', type = 'text', value = '北京'),
    html.Button(id = 'submit-button', n_clicks = 0, children = '點(diǎn)擊按鈕'),
    html.Div(id = 'output-state')
])

# 回調(diào)
@app.callback(Output('output-state', 'children'),
             [Input('submit-button', 'n_clicks')],
             [State('input01-state', 'value'),
              State('input02-state', 'value')])
def update_output(n_clicks, input01, input02):
    return f"""已經(jīng)點(diǎn)擊了{(lán)n_clicks}次按鈕,第一個輸入項是{input01}抒倚,第二個輸入項是{input02}"""
app

(二)效果圖

(三)說明

  1. dash.dependencies.State 允許傳遞額外值而不激活回調(diào)函數(shù)褐着。對比第一個基本回調(diào)的示例,本例中只是將dcc.Input 替換為 dash.dependencies.State 托呕,將按鈕替換為dash.dependencies.Input含蓉;
  2. 示例中,改變dcc.Input文本框中的文本不會激活回調(diào)函數(shù)项郊,點(diǎn)擊提交按鈕才會激活回調(diào)函數(shù)馅扣。需要注意,即使不會激活回調(diào)函數(shù)本身着降,但dcc.Input的現(xiàn)值依然會傳遞給回調(diào)函數(shù)差油;
  3. 觸發(fā)回調(diào)是通過html.Button組件的n_clicks屬性實現(xiàn)的,每次單擊組件時鹊碍,n_clicks都會增加厌殉,這個功能適用dash_html_components庫里的所有組件;

三侈咕、不顯示回調(diào)結(jié)果

(一) 代碼

app = JupyterDash('Prevent_id', height=50)

app.layout = html.Div([
    html.Button('點(diǎn)擊查看內(nèi)容', id = 'button_id'),
    html.Div(id = 'body-div')
])

@app.callback(Output(component_id = 'body-div', component_property = 'children'),
              [Input(component_id = 'button_id', component_property = 'n_clicks')])
def update_output(n_clicks):
    if n_clicks is None:
        raise PreventUpdate
    else:
        return '防止回調(diào)公罕,更新數(shù)據(jù)'
app

(二)效果圖

(三)說明

  1. 當(dāng)不希望更新回調(diào)的輸出結(jié)果時,可以通過 PreventUpdate 在回調(diào)函數(shù)中引發(fā)Exception 來實現(xiàn)此目的耀销;

四楼眷、其它

  1. dash.no_update可以實現(xiàn)部分更新輸出,按官方文檔目前沒有實現(xiàn)熊尉;
  2. 從dash>=0.36.0rc1版本后罐柳,支持單個調(diào)用中有多個輸出,按官方文檔目前并沒有實現(xiàn)(此處有捂臉狰住。张吉。。催植。有待后續(xù)更新)肮蛹。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末勺择,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子伦忠,更是在濱河造成了極大的恐慌省核,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件昆码,死亡現(xiàn)場離奇詭異气忠,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)赋咽,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進(jìn)店門旧噪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人冬耿,你說我怎么就攤上這事舌菜∶瓤牵” “怎么了亦镶?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長袱瓮。 經(jīng)常有香客問我缤骨,道長,這世上最難降的妖魔是什么尺借? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任绊起,我火速辦了婚禮,結(jié)果婚禮上燎斩,老公的妹妹穿的比我還像新娘虱歪。我一直安慰自己,他們只是感情好栅表,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布笋鄙。 她就那樣靜靜地躺著,像睡著了一般怪瓶。 火紅的嫁衣襯著肌膚如雪萧落。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天洗贰,我揣著相機(jī)與錄音找岖,去河邊找鬼。 笑死敛滋,一個胖子當(dāng)著我的面吹牛许布,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播绎晃,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼蜜唾,長吁一口氣:“原來是場噩夢啊……” “哼帖旨!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起灵妨,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤解阅,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后泌霍,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體货抄,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年朱转,在試婚紗的時候發(fā)現(xiàn)自己被綠了蟹地。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡藤为,死狀恐怖怪与,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情缅疟,我是刑警寧澤分别,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站存淫,受9級特大地震影響耘斩,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜桅咆,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一括授、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧岩饼,春花似錦荚虚、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至硕糊,卻和暖如春院水,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背简十。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工檬某, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人螟蝙。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓恢恼,卻偏偏與公主長得像,于是被迫代替她去往敵國和親胰默。 傳聞我的和親對象是個殘疾皇子场斑,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,722評論 2 345

推薦閱讀更多精彩內(nèi)容