百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

用 PyWebIO 在 Python 中创建交互式 Web 应用程序

off999 2024-11-08 12:53 16 浏览 0 评论

引言

用Python创建Web应用程序比几年前要容易得多。例如Streamlit,它彻底改变了我们在Python中创建和部署应用程序的方式。但是在本文中,我们将来介绍一下PyWebIO。

使用 PywebIO 构建简单的 web 应用程序很容易,不需要使用 HTML 和 Python 中的 Javascript。这个包的概念很简单: 您可以获得输入和输出函数,从而可以创建简单的 GUI 或 web 应用程序。

然后你可以从终端,交互式执行环境(如Python Shell,IPython或Jupyter Notebook)在本地或云中的浏览器中为Web应用程序提供服务。

要安装 PyWebIO,请运行以下命令。

pip install -U pywebio

输入与输出

PyWebIO是直观而直接的,你可以认为它是脚本、终端或交互式环境的扩展,使你能够轻松的创建web应用程序。

让我展示一个在 python 环境中运行的简单示例。在这里,我们创建不同类型的输入,包括文本输入、单选按钮和复选框。

# Text Input 
name = input('What is your Name?', type=TEXT) 

# Number Input 
name = input('How old are you?', type=TEXT) 

# Single choice 
answer = radio("Which Continent?", options=['Africa', 'Asia', 'Australia', 'Europe', 'North America', 'South America']) 

# Checkbox 
agree = checkbox("User Term", options=['I agree to terms and conditions'])

下面的 GIF 显示了如何在运行 python 代码时立即获得代码的浏览器 GUI。

是不是很酷啊!

在 Pywebio 有多种输入功能,你可以在这里(https://pywebio.readthedocs.io

/en/latest/input.html#functions-list)找到输入功能列表。

在前面的示例中,你已经看到了这些输入函数的几个示例。然而,我们往往倾向于将不同的输入分组,这就是 input_group 的作用。

让我们回顾一下第一个例子,使用 input _ group 函数将不同的输入打包在一起。注意,我们在所有输入中都有一个 name 参数。稍后我们将为每个输入使用 name 参数。

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

data = input_group(
    "User data",
    [
        input("What is your Name?", name="name", type=TEXT),
        input("Input your age", name="age", type=NUMBER),
        radio(
            "Which Continent?",
            name="continent",
            options=[
                "Africa",
                "Asia",
                "Australia",
                "Europe",
                "North America",
                "South America",
            ],
        ),
        checkbox(
            "User Term", name="agreement", options=["I agree to terms and conditions"]
        ),
    ],
)

你可能已经意识到,我们没有从前面的示例中得到任何输出,因为我们还没有创建任何输出函数。PyWebIO 有一个丰富的输出函数列表(https://pywebio.readthedocs.io/en/latest/output.html#functions-list),你可以参考它。

在这个例子中,我们只使用两个输出函数: put _ text_table 和 put _ table。注意,我们使用带有每个输入名称的输入组将它们放入表中。

put_text("The output in a table:")

put_table(
    [
        ["Name", data["name"]],
        ["Age", data["age"]],
        ["Continent", data["continent"]],
        ["Agreement", data["agreement"]],
    ]
)

下面是显示前面示例的分组输入和输出的 GIF。

这里最后一个例子向您展示了可以轻松地将 python 代码扩展到 Pywebio 应用程序中,而不需要做太多的更改。这个例子展示了一个简单的函数,它将对坐标进行格式化。

from pywebio.input import input, FLOAT, input_group
from pywebio.output import put_text
from pywebio import start_server


def print_coords(lat, long):
    lat, long = coordinates["lat"], coordinates["long"]

    ns = "NS"[lat < 0]  # True (1) defaults to "N" and False(0) defaults to "S"
    we = "EW"[long < 0]  # True (1) defaults to "E" and False(0) defaults to "W

    return f"{abs(lat):.2f}°{ns}, {abs(long):.2f}°{we}"



coordinates = input_group(
    "coordinates in decimal degrees",
    [
        input("Input Latitude:", name="lat", type=FLOAT),
        input("Input Longitude:", name="long", type=FLOAT),
    ],
)
put_text(print_coords(coordinates["lat"], coordinates["long"]))

下面是一个 GIF,显示了使用 PyWebIO 的简单坐标格式化应用程序。

数据可视化

PyWebIO把包括Plotly在内的多个数据可视化库集成在一起。以下示例创建一个Plotly映射,并将其与PyWebIO一起使用。

from pywebio.output import put_html
import plotly.express as px

df = px.data.gapminder().query("year==2007")
fig = px.scatter_geo(df, locations="iso_alpha", color="continent",
                     hover_name="country", size="pop",
                     projection="natural earth")
html = fig.to_html(include_plotlyjs="require", full_html=False)
put_html(html).send()

我们将 Plotly Figure 转换为 HTML,然后将其传递给 PyWebIO 中的 put_html 函数。

总结

我喜欢PyWebIO功能和概念的简单性。您可以获得输入和输出功能,这些功能使您可以将python代码转换为浏览器上的简单Web应用程序。此程序包中还有很多值得探索的地方,尤其是它允许您对应用程序进行样式设置和提供服务。一起来探索吧~

相关推荐

cad2014序列号和密钥永久(autocad2014序列号和密钥)

1在cad2014中修改标注样式后,需要将其保存2单击“样式管理器”按钮,在弹出的窗口中选择修改后的标注样式,然后单击“设置为当前”按钮,再单击“保存当前样式”按钮,将其保存为新的样式名称3为了...

qq修改密保手机号(qq修改密保手机号是什么意思)

QQ更改绑定的手机号码操作步骤如下:1、打开手机主界面,找到“QQ”软件点击打开。2、输入正确的QQ账户和密码登录到qq主界面。3、点击左上角的头像“图片”,进入到个人中心界面。4、进入到个人中心界面...

dell笔记本客服电话(dell笔记本客服电话人工服务)

戴尔中国的官方网站http://www.dell.com/zh-cn。通过这个网站购买的都没有问题;有问题也可以进入官网联系售后客服,也可以拔打dell电脑说明书上的售后热线,都可以为你解决的。还是建...

联想乐商店app官方下载(联想乐商店在哪下载)

您好!很遗憾!若是您的手机联想乐商店和联想游戏中心只能有流量,建议您核实是否乐安全有限制wifi上网,核实您所使用的wifi是否本身有限制。若还是无效,可清除缓存数据;备份资料恢复出厂设置尝试。欢迎您...

fat32u盘(FAT32u盘多少钱一个)
  • fat32u盘(FAT32u盘多少钱一个)
  • fat32u盘(FAT32u盘多少钱一个)
  • fat32u盘(FAT32u盘多少钱一个)
  • fat32u盘(FAT32u盘多少钱一个)
不用拉网线的路由器是真的吗

是真的不插卡不拉线有线就有网,这11个字其实就涵盖了无线路由器的特点,无线路由器免插卡、不用拉网线,完全摆脱了之前家用路由器和网线捆绑的模式,有电就有网,其实说的就是无线路由器的使用操作简单,通电就可...

微信恢复好友怎么弄回来(vx好友恢复)
  • 微信恢复好友怎么弄回来(vx好友恢复)
  • 微信恢复好友怎么弄回来(vx好友恢复)
  • 微信恢复好友怎么弄回来(vx好友恢复)
  • 微信恢复好友怎么弄回来(vx好友恢复)
u盘检测软件下载(u盘测试软件)

1、u盘芯片检测工具(ChipEasy)可以查看USB设备PID、VID、SN、制造商、产品名等;2、查看USB设备主控芯片信息、闪存芯片信息、固件信息、电流控制3、SSD型号...

电脑现在什么系统最好(电脑现在用什么系统好)

WINXP好用,但过时了。VISTA不好用,没推开就夭折了。WIN8/8.1是针对触模屏设计的,如果你用的不是触摸屏平板电脑是普通电脑,使WIN8/8.1总觉着很蹩扭。新出的WIN10,功能...

账号怎么注册(steam账号怎么注册)

如果注册是qq账号【qq号码的申请办法】【1】双击qq登陆界面,在qq帐号填写空格的后面你可以看见:[申请帐号];【2】点击[申请帐号]进入,就可以在网上免费申请号码了;【3】进入www.qq.com...

tmp文件是什么意思(tmp文件有什么用)

在系统C:\Windows\Temp文件夹中,我们经常会发现一些后缀名为TMP的文件,在该文件夹中的这些文件其实都是临时文件。它们可能是系统被误关机,或者其他程序没有删除而生的。而且在该文件夹中还有其...

怎么给u盘格式化(怎么给u盘格式化成FAT32)

u盘插入电脑,等待桌面弹出u盘图标。打开“计算机”。左键选中u盘,单击右键,在弹出的菜单中,点击“格式化”。点击“开始”,点击“确定”即可。格式化u盘详细步骤1、找到U盘盘符,鼠标右键点击,弹出菜单中...

harmonyos主题下载(harmonyos主题怎么换)

首先,打开荣耀手机的应用市场,在搜索框中输入“华为鸿蒙主题”,然后点击搜索。找到“华为鸿蒙主题”应用后,点击下载即可。下载完成后,打开“华为鸿蒙主题”应用,选择心仪的主题,点击下载并应用即可享受华为鸿...

戴尔笔记本电脑黑屏却开着机

对于电脑黑屏的处理基本上采用排除、替换相结合的方法,其原则应本着先替换排除可疑性最大的部件。对于普通电脑用户来讲,专业知识不足,可以按下列步骤分析故障原因,以便可以自己动手排除故障。首先检查接触是否良...

手机版电脑桌面下载(手机电脑桌面下载软件安装包)

只有电脑版手机助手软件,没有手机桌面这个软件在电脑上点击今日头条APP下载安装即可哦你好,陌陌电脑版如果说你想要下载到电脑桌面的话,你只需要长按把它添加到你的电脑桌面就可以了。要将软件下载到桌面并创建...

取消回复欢迎 发表评论: