脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Python - python中的PywebIO模块制作一个数据大屏

python中的PywebIO模块制作一个数据大屏

2022-10-21 11:18Python学习与数据挖掘 Python

这篇文章主要介绍了python中的PywebIO模块制作一个数据大屏,一个制作数据大屏的工具,非常的好用,100行的Python代码就可以制作出来一个完整的数据大屏,并且代码的逻辑非常容易理解,需要的朋友可以参考一下

一、PywebIO介绍

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:

python中的PywebIO模块制作一个数据大屏

上述代码的逻辑并不难看懂,先实例化一个直方图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:

python中的PywebIO模块制作一个数据大屏

 

二、PywebIO和Pyecharts的组合

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:

python中的PywebIO模块制作一个数据大屏

 

三、PywebIO和Bokeh的组合

PywebIOBokeh的组合从代码的语法上来看会稍微和上面的不太一样,具体的不同如下所示:

  1. from bokeh.io import output_notebook 
  2. from bokeh.io import show 
  3.  
  4. output_notebook(notebook_type="pywebio"
  5. fig = figure(...) 
  6. ... 
  7. show(fig) 

例如我们来绘制一个简单的直方图,代码如下:

  1. def bar_plots(): 
  2.  
  3.     output_notebook(notebook_type="pywebio"
  4.     fruits = ["Apples""Pears""Nectarines""Plums""Grapes""Strawberries"
  5.     counts = [5, 3, 4, 2, 4, 6] 
  6.  
  7.     p = figure(x_range=fruits, plot_height=350, title="Fruit Counts"
  8.                toolbar_location=None, tools=""
  9.  
  10.     p.vbar(x=fruits, top=counts, width=0.9) 
  11.     p.xgrid.grid_line_color = None 
  12.     p.y_range.start = 0 
  13.  
  14.     show(p) 
  15.  
  16. if __name__ == "__main__"
  17.     start_server(bar_plots, debug=True, port=8080) 

output:

python中的PywebIO模块制作一个数据大屏

 

四、基于浏览器的GUI应用

除了将Pywebio模块与常用的可视化模块结合用于各种图表的绘制之外,我们还能用它构建一个基于浏览的图形界面,我们先来做一个最为简单的应用,代码如下:

  1. from pywebio.input import * 
  2. from pywebio.output import * 
  3.  
  4. data = input_group( 
  5.     "用户数据"
  6.     [ 
  7.         input("请问您的名字是: ", name="name", type=TEXT), 
  8.         input("输入您的年龄", name="age", type=NUMBER), 
  9.         radio( 
  10.             "哪个洲的"
  11.             name="continent"
  12.             options=[ 
  13.                 "非洲"
  14.                 "亚洲"
  15.                 "澳大利亚"
  16.                 "欧洲"
  17.                 "北美洲"
  18.                 "南美洲"
  19.             ], 
  20.         ), 
  21.         checkbox( 
  22.             "用户隐私条例", name="agreement", options=["同意"
  23.         ), 
  24.     ], 
  25.  
  26. put_text("表格输出:"
  27.  
  28. put_table( 
  29.     [ 
  30.         ["名字", data["name"]], 
  31.         ["年龄", data["age"]], 
  32.         ["位置", data["continent"]], 
  33.         ["条例", data["agreement"]], 
  34.     ] 

output:

python中的PywebIO模块制作一个数据大屏

当中部分函数方法的解释如下:

  • input(): 文本内容的输入
  • radio(): 代表的是单选框
  • checkbox(): 代表的是多选框
  • input_group(): 代表的是输入组
  • put_table(): 代表的是输出组
  • put_text(): 代表的是输出文本

到此这篇关于python中的PywebIO模块制作一个数据大屏的文章就介绍到这了,更多相关PywebIO制作数据大屏内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文地址:https://blog.csdn.net/weixin_38037405/article/details/122807489

延伸 · 阅读

精彩推荐
  • Pythonpython利用google翻译方法实例(翻译字幕文件)

    python利用google翻译方法实例(翻译字幕文件)

    这篇文章主要给大家介绍了关于python利用google翻译(翻译字幕文件)的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参...

    夏_徐_梁3582020-09-22
  • Python使用TensorFlow对图像进行随机旋转的实现示例

    使用TensorFlow对图像进行随机旋转的实现示例

    这篇文章主要介绍了使用TensorFlow对图像进行随机旋转的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需...

    LiangJun.py8982020-04-09
  • PythonPython Socket 编程知识点详细介绍

    Python Socket 编程知识点详细介绍

    这篇文章主要介绍了Python Socket 编程,Socket又称为套接字,它是所有网络通信的基础。网络通信其实就是进程间的通信,Socket主要是使用IP地址,协议,端口...

    Python进阶者9052022-10-11
  • Pythonpython正向最大匹配分词和逆向最大匹配分词的实例

    python正向最大匹配分词和逆向最大匹配分词的实例

    今天小编就为大家分享一篇python正向最大匹配分词和逆向最大匹配分词的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    yan456jie7962021-04-19
  • PythonPython PyQt5实战项目之文件拷贝器的具体实现详解

    Python PyQt5实战项目之文件拷贝器的具体实现详解

    PyQt5以一套Python模块的形式来实现功能。它包含了超过620个类,600个方法和函数。本篇文章手把手带你用PyQt5实现一个简单的文件拷贝器,大家可以在过程中...

    不侠居8112022-02-26
  • PythonPandas爆炸函数的使用技巧

    Pandas爆炸函数的使用技巧

    同事举了个简单的例子来说明爆炸函数的功能,我当场就记下了这个函数名称:爆炸函数。Hive在我的工作中使用的并不多,于是我在想:Pandas能够实现这个...

    尤尔小屋的猫12102021-11-04
  • PythonPython连接字符串过程详解

    Python连接字符串过程详解

    这篇文章主要介绍了python连接字符串过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...

    小小程序员ol5812020-05-08
  • Python深入理解Python装饰器

    深入理解Python装饰器

    装饰器(decorator)是一种高级Python语法。装饰器可以对一个函数、方法或者类进行加工。这篇文章主要介绍了深入理解Python装饰器的相关资料,需要的朋友可以...

    iVictor2532020-09-03