99999久久久久久亚洲,欧美人与禽猛交狂配,高清日韩av在线影院,一个人在线高清免费观看,啦啦啦在线视频免费观看www

熱線電話:13121318867

登錄
首頁精彩閱讀用Python當(dāng)中Plotly.Express模塊繪制幾張圖表,真的被驚艷到了
用Python當(dāng)中Plotly.Express模塊繪制幾張圖表,真的被驚艷到了
2022-06-20
收藏

作者:俊欣

來源:關(guān)于數(shù)據(jù)分析與可視化

相信大家對一些常規(guī)的可視化圖表都比較熟悉了,例如像是折線圖柱狀圖、餅圖等等,今天小編通過Plotly Express模塊來為大家繪制幾個不常見但是特別驚艷的圖表。

SunBurst Chart

SunBurst Chart大家一般稱作是旭日圖或者是太陽圖,和餅圖的結(jié)構(gòu)十分地相似,但是比后者更加能表達(dá)清晰的層級和歸屬關(guān)系。在旭日圖當(dāng)中,離圓點(diǎn)越近表示級別就越高,相鄰兩層中是內(nèi)層包含外層的關(guān)系。

在實(shí)際項(xiàng)目當(dāng)中使用旭日圖,不僅數(shù)據(jù)直觀,而且圖表使用起來特別的酷炫,可以迅速地拉高數(shù)據(jù)匯報的顏值。代碼如下

import plotly.express as px import numpy as np
df = px.data.gapminder().query("year == 2002")
fig = px.sunburst(df, path=['continent', 'country'], values='pop',
                  color='lifeExp', hover_data=['iso_alpha'],
                  color_continuous_scale='RdBu',
                  color_continuous_midpoint=np.average(df['lifeExp'], weights=df['pop']))
fig.show()

output

用Python當(dāng)中Plotly.Express模塊繪制幾張圖表,真的被驚艷到了

當(dāng)中的textinfo參數(shù)來調(diào)整標(biāo)簽的表達(dá)形式,例如以百分比的形式來顯示所占的比例,代碼如下

fig = px.sunburst(...和上面的代碼一樣...)
fig.update_traces(
    textinfo="label+percent entry" )
fig.show()

output

用Python當(dāng)中Plotly.Express模塊繪制幾張圖表,真的被驚艷到了

Treemap

樹形圖(Treemap)適用于層級結(jié)構(gòu)更加鮮明的數(shù)據(jù)當(dāng)中,在一個樹形圖中,圖表被分割成了若干個矩形,其中矩形的大小有數(shù)值的大小而定,我們來看一下具體的代碼實(shí)現(xiàn)

fig = px.treemap(df, path=[px.Constant("world"), 'continent', 'country'], values='pop',
                  color='lifeExp', hover_data=['iso_alpha'],
                  color_continuous_scale='RdBu',
                  color_continuous_midpoint=np.average(df['lifeExp'], weights=df['pop']))
fig.update_layout(margin = dict(t=50, l=25, r=25, b=25))
fig.show()

output

用Python當(dāng)中Plotly.Express模塊繪制幾張圖表,真的被驚艷到了

Polar Charts

plotly.express模塊當(dāng)中,我們既可以在極坐標(biāo)圖當(dāng)中添加散點(diǎn),也可以在上面放置折線,其中極坐標(biāo)中的散點(diǎn)圖調(diào)用的是px.scatter_polar()方法來實(shí)現(xiàn),代碼如下

import plotly.express as px
df = px.data.wind()
fig = px.scatter_polar(df, r="frequency", theta="direction",
                       color="strength", symbol="strength", size="frequency",
                       color_discrete_sequence=px.colors.sequential.Plasma_r)
fig.show()

output

用Python當(dāng)中Plotly.Express模塊繪制幾張圖表,真的被驚艷到了

極坐標(biāo)中的折線圖調(diào)用的則是px.line_polar()方法,代碼如下

fig = px.line_polar(df, r="frequency", theta="direction", color="strength", line_close=True,
                    color_discrete_sequence=px.colors.sequential.Plasma_r, template="plotly_dark",)
fig.show()

output

用Python當(dāng)中Plotly.Express模塊繪制幾張圖表,真的被驚艷到了

Gantt Charts

?;鶊D(Gantt Charts)被用來表示項(xiàng)目工程的進(jìn)展十分有幫助,其中縱軸表示的是項(xiàng)目的名稱,橫軸表示的是日期,能夠非常直觀地表達(dá)項(xiàng)目的周期以及進(jìn)展,代碼如下

df = pd.DataFrame([
    dict(Task="Job A", Start='2009-01-01', Finish='2009-02-28'),
    dict(Task="Job B", Start='2009-03-05', Finish='2009-04-15'),
    dict(Task="Job C", Start='2009-02-20', Finish='2009-05-30')
])

df.head()

output

用Python當(dāng)中Plotly.Express模塊繪制幾張圖表,真的被驚艷到了

數(shù)據(jù)當(dāng)中有項(xiàng)目的開始日期和結(jié)束日期,然后我們調(diào)用px.timeline方法來繪制成?;鶊D,代碼如下

fig = px.timeline(df, x_start="Start", x_end="Finish", y="Task")
fig.update_yaxes(autorange="reversed")
fig.show()

output

用Python當(dāng)中Plotly.Express模塊繪制幾張圖表,真的被驚艷到了

當(dāng)然要是不同的項(xiàng)目由不用的人來負(fù)責(zé),我們也可以在圖表上面標(biāo)注出來,代碼如下

df = pd.DataFrame([
    dict(Task="Job A", StartDate='2009-01-01', FinishDate='2009-02-28', PorjectManager="小王"),
    dict(Task="Job B", StartDate='2009-03-05', FinishDate='2009-04-15', PorjectManager="小王"),
    dict(Task="Job C", StartDate='2009-02-20', FinishDate='2009-05-30', PorjectManager="小李")
])

fig = px.timeline(df, x_start="StartDate", x_end="Finish", y="Task", color="PorjectManager")
fig.update_yaxes(autorange="reversed")
fig.show()

output

用Python當(dāng)中Plotly.Express模塊繪制幾張圖表,真的被驚艷到了

當(dāng)然項(xiàng)目的完成進(jìn)度也可以在圖表上面表示出來,代碼如下

df = pd.DataFrame([
    dict(Task="Job A", StartDate='2009-01-01', FinishDate='2009-02-25', Completion_pct=60),
    dict(Task="Job B", StartDate='2009-03-05', FinishDate='2009-04-15', Completion_pct=40),
    dict(Task="Job C", StartDate='2009-02-20', FinishDate='2009-05-30', Completion_pct=75)
])

fig = px.timeline(df, x_start="StartDate", x_end="FinishDate", y="Task", color="Completion_pct")
fig.update_yaxes(autorange="reversed")
fig.show()

output

用Python當(dāng)中Plotly.Express模塊繪制幾張圖表,真的被驚艷到了

Map

plotly.express模塊當(dāng)中繪制地圖也是十分的簡單,例如我們繪制的是地圖當(dāng)中的散點(diǎn)圖,調(diào)用的是scatter_geo()方法,代碼如下

df = px.data.gapminder().query("year == 2002")
fig = px.scatter_geo(df, locations="iso_alpha",
                     size="pop",
                     )
fig.show()

output

用Python當(dāng)中Plotly.Express模塊繪制幾張圖表,真的被驚艷到了

我們可以在此基礎(chǔ)之上再進(jìn)一步進(jìn)行圖表的美化,例如不同的國家表示不同的州用不同顏色的散點(diǎn)來表示,代碼如下

fig = px.scatter_geo(df, locations="iso_alpha",
                     color="continent", 
                     hover_name="country", 
                     size="pop", 
                     projection="natural earth")
fig.show()

output

用Python當(dāng)中Plotly.Express模塊繪制幾張圖表,真的被驚艷到了

以及分級統(tǒng)計(jì)圖(Choropleth map),具體指的是在整個制圖區(qū)域內(nèi),每個區(qū)劃單元根據(jù)各分區(qū)劃分出來的數(shù)量來進(jìn)行分級,調(diào)用的是px.choropleth()方法

fig = px.choropleth(df, geojson=geojson, color="Bergeron",
                    locations="district", featureidkey="properties.district",
                    projection="mercator" )
fig.update_geos(fitbounds="locations", visible=False)
fig.update_layout(margin={"r":0,"t":0,"l":0,"b":0})
fig.show()

output

用Python當(dāng)中Plotly.Express模塊繪制幾張圖表,真的被驚艷到了

數(shù)據(jù)分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數(shù)據(jù)分析師資訊
更多

OK
客服在線
立即咨詢
客服在線
立即咨詢
') } function initGt() { var handler = function (captchaObj) { captchaObj.appendTo('#captcha'); captchaObj.onReady(function () { $("#wait").hide(); }).onSuccess(function(){ $('.getcheckcode').removeClass('dis'); $('.getcheckcode').trigger('click'); }); window.captchaObj = captchaObj; }; $('#captcha').show(); $.ajax({ url: "/login/gtstart?t=" + (new Date()).getTime(), // 加隨機(jī)數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調(diào)用 initGeetest 進(jìn)行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調(diào),回調(diào)的第一個參數(shù)驗(yàn)證碼對象,之后可以使用它調(diào)用相應(yīng)的接口 initGeetest({ // 以下 4 個配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺檢測極驗(yàn)服務(wù)器是否宕機(jī) new_captcha: data.new_captcha, // 用于宕機(jī)時表示是新驗(yàn)證碼的宕機(jī) product: "float", // 產(chǎn)品形式,包括:float,popup width: "280px", https: true // 更多配置參數(shù)說明請參見:http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計(jì)時完成 $(".getcheckcode").removeClass('dis').html("重新獲取"); }else{ $(".getcheckcode").addClass('dis').html("重新獲取("+_wait+"s)"); _wait--; setTimeout(function () { codeCutdown(); },1000); } } function inputValidate(ele,telInput) { var oInput = ele; var inputVal = oInput.val(); var oType = ele.attr('data-type'); var oEtag = $('#etag').val(); var oErr = oInput.closest('.form_box').next('.err_txt'); var empTxt = '請輸入'+oInput.attr('placeholder')+'!'; var errTxt = '請輸入正確的'+oInput.attr('placeholder')+'!'; var pattern; if(inputVal==""){ if(!telInput){ errFun(oErr,empTxt); } return false; }else { switch (oType){ case 'login_mobile': pattern = /^1[3456789]\d{9}$/; if(inputVal.length==11) { $.ajax({ url: '/login/checkmobile', type: "post", dataType: "json", data: { mobile: inputVal, etag: oEtag, page_ur: window.location.href, page_referer: document.referrer }, success: function (data) { } }); } break; case 'login_yzm': pattern = /^\d{6}$/; break; } if(oType=='login_mobile'){ } if(!!validateFun(pattern,inputVal)){ errFun(oErr,'') if(telInput){ $('.getcheckcode').removeClass('dis'); } }else { if(!telInput) { errFun(oErr, errTxt); }else { $('.getcheckcode').addClass('dis'); } return false; } } return true; } function errFun(obj,msg) { obj.html(msg); if(msg==''){ $('.login_submit').removeClass('dis'); }else { $('.login_submit').addClass('dis'); } } function validateFun(pat,val) { return pat.test(val); }