<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
Python
當中的PywebIO
模組可以幫助開發者在不具備HTML和JavaScript的情況下也能夠迅速構建Web應用或者是基於瀏覽器的GUI應用,PywebIO還可以和一些常用的視覺化模組聯用,製作成一個視覺化大屏,
我們先來安裝好需要用到的模組
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:
上述程式碼的邏輯並不難看懂,先範例化一個直方圖Bar()物件,然後填上X軸對應的標籤以及對應Y軸的值,最後呼叫PywebIO模組當中的put_html()
方法,我們會看到一個URL
在瀏覽器當中輸入該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:
當PywebIO
模組遇上Pyecharts
模組時,程式碼的邏輯基本上和cutecharts
的一致,先是範例化一個圖表的物件,然後在新增完資料以及設定好圖表的樣式之後,最後呼叫put_html()
方法將最後的結果在瀏覽器中呈現
# `chart` 是你的圖表的範例 pywebio.output.put_html(chart.render_notebook())
在這個案例當中我們呼叫Pyecharts當中的組合元件,分別來呈現繪製完成的圖表,程式碼如下:
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:
PywebIO
和Bokeh
的組合從程式碼的語法上來看會稍微和上面的不太一樣,具體的不同如下所示:
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:
除了將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:
當中部分函數方法的解釋如下:
input()
: 文字內容的輸入radio()
: 代表的是單選框checkbox()
: 代表的是多選框input_group()
: 代表的是輸入組put_table()
: 代表的是輸出組put_text()
: 代表的是輸出文字到此這篇關於python中的PywebIO模組製作一個資料大屏的文章就介紹到這了,更多相關PywebIO製作資料大屏內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45