python中的PywebIO模塊制作一個數(shù)據(jù)大屏
一、PywebIO介紹
Python當(dāng)中的PywebIO模塊可以幫助開發(fā)者在不具備HTML和JavaScript的情況下也能夠迅速構(gòu)建Web應(yīng)用或者是基于瀏覽器的GUI應(yīng)用,PywebIO還可以和一些常用的可視化模塊聯(lián)用,制作成一個可視化大屏,
我們先來安裝好需要用到的模塊
pip install pywebio pip install cutecharts
上面提到的cutecharts模塊是Python當(dāng)中的手繪風(fēng)格的可視化神器,相信大家對此并不陌生,我們來看一下它與PywebIO模塊結(jié)合繪制圖表的效果是什么樣的,
代碼如下:
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īng)的標(biāo)簽以及對應(yīng)Y軸的值,最后調(diào)用PywebIO模塊當(dāng)中的put_html()方法,我們會看到一個URL
在瀏覽器當(dāng)中輸入該URL便能夠看到我們繪制出來的圖表。當(dāng)然在cutecharts模塊當(dāng)中有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("標(biāo)題", width="100%")
? ? ........
? ? return chart
def radar_base() -> Radar:
? ? chart = Radar("標(biāo)題", width="100%")
? ? ......
? ? return chart
def line_base() -> Line:
? ? chart = Line("標(biāo)題", 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的組合
當(dāng)PywebIO模塊遇上Pyecharts模塊時,代碼的邏輯基本上和cutecharts的一致,先是實例化一個圖表的對象,然后在添加完數(shù)據(jù)以及設(shè)置好圖表的樣式之后,最后調(diào)用put_html()方法將最后的結(jié)果在瀏覽器中呈現(xiàn)
# `chart` 是你的圖表的實例 pywebio.output.put_html(chart.render_notebook())
在這個案例當(dāng)中我們調(diào)用Pyecharts當(dāng)中的組合組件,分別來呈現(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:

三、PywebIO和Bokeh的組合
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:

四、基于瀏覽器的GUI應(yīng)用
除了將Pywebio模塊與常用的可視化模塊結(jié)合用于各種圖表的繪制之外,我們還能用它構(gòu)建一個基于瀏覽的圖形界面,我們先來做一個最為簡單的應(yīng)用,代碼如下:
from pywebio.input import *
from pywebio.output import *
data = input_group(
? ? "用戶數(shù)據(jù)",
? ? [
? ? ? ? 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:

當(dāng)中部分函數(shù)方法的解釋如下:
input(): 文本內(nèi)容的輸入radio(): 代表的是單選框checkbox(): 代表的是多選框input_group(): 代表的是輸入組put_table(): 代表的是輸出組put_text(): 代表的是輸出文本
到此這篇關(guān)于python中的PywebIO模塊制作一個數(shù)據(jù)大屏的文章就介紹到這了,更多相關(guān)PywebIO制作數(shù)據(jù)大屏內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python實現(xiàn)簡單飛機(jī)大戰(zhàn)
這篇文章主要為大家詳細(xì)介紹了Python實現(xiàn)簡單飛機(jī)大戰(zhàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-07-07
Python 分析Nginx訪問日志并保存到MySQL數(shù)據(jù)庫實例
這篇文章主要介紹了Python 分析Nginx訪問日志并保存到MySQL數(shù)據(jù)庫實例,需要的朋友可以參考下2014-03-03
Python?Flask實現(xiàn)后臺任務(wù)輕松構(gòu)建高效API應(yīng)用
本文介紹如何使用Python?Flask框架實現(xiàn)后臺任務(wù),以快速構(gòu)建高效的API應(yīng)用。通過實例演示,讀者將學(xué)會如何利用Flask框架搭建后臺任務(wù),實現(xiàn)異步處理和多線程操作等高級功能,提升應(yīng)用性能和用戶體驗2023-04-04
windows10在visual studio2019下配置使用openCV4.3.0
這篇文章主要介紹了windows10在visual studio2019下配置使用openCV4.3.0,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
使用Python構(gòu)建Hopfield網(wǎng)絡(luò)的教程
這篇文章主要介紹了使用Python構(gòu)建Hopfield網(wǎng)絡(luò)的教程,本文來自于IBM官方網(wǎng)站的技術(shù)文檔,需要的朋友可以參考下2015-04-04
解決python字典對值(值為列表)賦值出現(xiàn)重復(fù)的問題
今天小編就為大家分享一篇解決python字典對值(值為列表)賦值出現(xiàn)重復(fù)的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-01-01

