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

熱線電話:13121318867

登錄
首頁精彩閱讀3000字推薦一個可視化神器,50行Python代碼制作數據大屏(CDA干貨內容分享)
3000字推薦一個可視化神器,50行Python代碼制作數據大屏(CDA干貨內容分享)
2022-01-07
收藏

作者:俊欣

來源:關于數據分析與可視化

大家好,今天又是周五了,可能是打工人最開心的日子

今天小編給大家分享一個制作數據大屏的工具,非常的好用,100行左右的Python代碼就可以制作出來一個完整的數據大屏,并且代碼的邏輯非常容易理解。

PywebIO介紹

Python當中的PywebIO模塊可以幫助開發(fā)者在不具備HTMLJavaScript的情況下也能夠迅速構建Web應用或者是基于瀏覽器的GUI應用,PywebIO還可以和一些常用的可視化模塊聯(lián)用,制作成一個可視化大屏,

我們先來安裝好需要用到的模塊

pip install pywebio pip install cutecharts 

上面提到的cutecharts模塊是Python當中的手繪風格的可視化神器,相信大家對此并不陌生,我們來看一下它與PywebIO模塊結合繪制圖表的效果是什么樣的,代碼如下

from cutecharts.charts import Bar from cutecharts.faker import Faker from pywebio import start_server from pywebio.output import put_html def bar_base(): chart = Bar("Bar-基本示例", width="100%")
    chart.set_options(labels=Faker.choose(), x_label="I'm xlabel", y_label="I'm ylabel")
    chart.add_series("series-A", Faker.values())
    put_html(chart.render_notebook()) if __name__ == '__main__':
    start_server(bar_base, debug=True, port=8080)

output

3000字推薦一個可視化神器,50行Python代碼制作數據大屏

上述代碼的邏輯并不難看懂,先實例化一個直方圖Bar()對象,然后填上X軸對應的標簽以及對應Y軸的值,最后調用PywebIO模塊當中的put_html()方法,我們會看到一個URL

3000字推薦一個可視化神器,50行Python代碼制作數據大屏

在瀏覽器當中輸入該URL便能夠看到我們繪制出來的圖表。當然在cutecharts模塊當中有Page()方法來將各個圖表都連接起來,做成一張可視化大屏,代碼如下

def bar_base(): chart = Bar("Bar-基本示例", width="100%")
    chart.set_options(labels=Faker.choose(), x_label="I'm xlabel", y_label="I'm ylabel")
    chart.add_series("series-A", Faker.values()) return chart def pie_base() -> Pie: chart = Pie("標題", width="100%")
    ........ return chart def radar_base() -> Radar: chart = Radar("標題", width="100%")
    ...... return chart def line_base() -> Line: chart = Line("標題", width="100%")
    ...... return chart def main(): page = Page()
    page.add(pie_base(), pie_base(), radar_base(), line_base(), bar_base())
    put_html(page.render_notebook()) if __name__ == '__main__':
    start_server(main, debug=True, port=8080)

output

3000字推薦一個可視化神器,50行Python代碼制作數據大屏

PywebIO和Pyecharts的組合

PywebIO模塊遇上Pyecharts模塊時,代碼的邏輯基本上和cutecharts的一致,先是實例化一個圖表的對象,然后在添加完數據以及設置好圖表的樣式之后,最后調用put_html()方法將最后的結果在瀏覽器中呈現(xiàn)

# `chart` 是你的圖表的實例 pywebio.output.put_html(chart.render_notebook())

在這個案例當中我們調用Pyecharts當中的組合組件,分別來呈現(xiàn)繪制完成的圖表,代碼如下

def bar_plots(): bar = (
        Bar()
            .add_xaxis(Faker.choose())
            .add_yaxis("商家A", Faker.values())
            .add_yaxis("商家B", Faker.values())
            .set_global_opts(title_opts=opts.TitleOpts(title="Grid-Bar"))
    ) return bar def line_plots(): line = (
        Line()
            .add_xaxis(Faker.choose())
            .add_yaxis("商家A", Faker.values())
            .add_yaxis("商家B", Faker.values())
            .set_global_opts(
            title_opts=opts.TitleOpts(title="Grid-Line", pos_top="48%"),
            legend_opts=opts.LegendOpts(pos_top="48%"),
        )
    ) return line def main(): c = (
        Grid()
            .add(bar_plots(), grid_opts=opts.GridOpts(pos_bottom="60%"))
            .add(line_plots(), grid_opts=opts.GridOpts(pos_top="60%"))
    )
    c.width = "100%" put_html(c.render_notebook()) if __name__ == '__main__':
    start_server(main, debug=True, port=8080)

output

3000字推薦一個可視化神器,50行Python代碼制作數據大屏

PywebIO和Bokeh的組合

PywebIOBokeh的組合從代碼的語法上來看會稍微和上面的不太一樣,具體的不同如下所示

from bokeh.io import output_notebook from bokeh.io import show

output_notebook(notebook_type='pywebio')
fig = figure(...)
...
show(fig)

例如我們來繪制一個簡單的直方圖,代碼如下

def bar_plots(): output_notebook(notebook_type='pywebio')
    fruits = ['Apples', 'Pears', 'Nectarines', 'Plums', 'Grapes', 'Strawberries']
    counts = [5, 3, 4, 2, 4, 6]

    p = figure(x_range=fruits, plot_height=350, title="Fruit Counts",
               toolbar_location=None, tools="")

    p.vbar(x=fruits, top=counts, width=0.9)
    p.xgrid.grid_line_color = None p.y_range.start = 0 show(p) if __name__ == "__main__":
    start_server(bar_plots, debug=True, port=8080)

output

3000字推薦一個可視化神器,50行Python代碼制作數據大屏

基于瀏覽器的GUI應用

除了將Pywebio模塊與常用的可視化模塊結合用于各種圖表的繪制之外,我們還能用它構建一個基于瀏覽的圖形界面,我們先來做一個最為簡單的應用,代碼如下

from pywebio.input import * from pywebio.output import *

data = input_group( "用戶數據",
    [ input("請問您的名字是: ", name="name", type=TEXT),
        input("輸入您的年齡", name="age", type=NUMBER),
        radio( "哪個洲的",
            name="continent",
            options=[ "非洲", "亞洲", "澳大利亞", "歐洲", "北美洲", "南美洲", ],
        ),
        checkbox( "用戶隱私條例", name="agreement", options=["同意"]
        ),
    ],
)

put_text("表格輸出:")

put_table(
    [ ["名字", data["name"]],
        ["年齡", data["age"]],
        ["位置", data["continent"]],
        ["條例", data["agreement"]],
    ]
)

output

3000字推薦一個可視化神器,50行Python代碼制作數據大屏

當中部分函數方法的解釋如下:

  • input(): 文本內容的輸入
  • radio(): 代表的是單選框
  • checkbox(): 代表的是多選框
  • input_group(): 代表的是輸入組
  • put_table(): 代表的是輸出組
  • put_text(): 代表的是輸出文本

數據分析咨詢請掃描二維碼

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

數據分析師資訊
更多

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(), // 加隨機數防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調用 initGeetest 進行初始化 // 參數1:配置參數 // 參數2:回調,回調的第一個參數驗證碼對象,之后可以使用它調用相應的接口 initGeetest({ // 以下 4 個配置參數為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺檢測極驗服務器是否宕機 new_captcha: data.new_captcha, // 用于宕機時表示是新驗證碼的宕機 product: "float", // 產品形式,包括:float,popup width: "280px", https: true // 更多配置參數說明請參見:http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計時完成 $(".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); }