网站首页 > 技术文章 正文
界面的制作一直是 Python 的痛!使用 Python 制作桌面端界面是非常痛苦的过程(又难学又难看)。不过,Python 已经出现了几个基于web前端的库,他们的基本机制大同小异,如果对 界面操作性没有太大要求,那么这些库就比较适合你 。
这个系列基于 pywebio 的一系列实战应用,让我们从实战中学习这个库的使用!
如果对你有帮助,记得转发推荐给你的好友!
你的点赞、收藏是对我的最大鼓励!
本节源码回复"pywebio"即可获取
本文是对多种交互界面的套路,以及 pywebio 中对应解决方式的讲解。是本系列后续实战案例的关键,如果你是能尽快上手 pywebio 或 streamlit 这些库,那么请务必好好理解
上一节:
Python新晋界面库pywebio,不会这个技巧不可能用好它
本节最终效果:
- 选择文件加载
- 文本框输入查询条件,下方刷新显示筛选结果
安装库:
pip install -U pywebio
布局
虽然需求比较简单,但我们还是希望培养一种好习惯。
首先利用作用域对整个页面做布局:
- 行9-11:这是本系列第一节的内容
- 行13:定义一个作用域 query_input
- 行15:使用 pin.put_input 得到一个不阻塞的输入框
- 行16:执行查询按钮,此时我们还没有输入第二个参数
- 行18:定义一个作用域 table ,里面就是用于显示表格
这里定义作用域是为了方便后续对页面的不同部分内容做修改
关于作用域,pin 等内容都在本系列章节有详细讲解,请回看
其实现在界面就可以正常显示,但是当点击"查询"按钮时,就会报错:
这是因为我们没有告诉按钮,点击时要执行什么操作
查询逻辑
现在可以定义按钮点击时的处理:
- 行10-13:定义函数,接受一个 DataFrame 参数
- 行11:现在可以通过 pin 获取输入框的内容,注意此时的 pin_query 要与行21 的对应
- 行12:此时体现作用域的作用,我们可以在代码任何位置上更新表格
- 行27:hold 方法相当重要,因为当你看到数据表出现时,自定义函数已经执行完毕,hold 方法让 pywebio 保持自定义中定义的所有数据(包括自定义函数),否则点击按钮不会起作用(因为函数 when click query 已经被销毁)
如果输入框与按钮在同一行,界面会比较合理:
- 行22:output.put_row([控件1,控件2,……]) 可以让多个控件放置同一行上
现在界面:
有时候我们只是简单对一列作为条件筛选,每次都要输入长长的查询字符串,太麻烦了!
下一节,我们继续增强功能,效果如下:
- 自动列出数据表中的文本类型的列名,只需要选择即可
- 选择列后,会出现列中各类文本的选项,同样只需要选择即可(单选或多选)
推荐阅读:
- 上一篇: 前端不会消失,前端的你可能会消失
- 下一篇: 新手必看 | 一学就会!原来web网页布局是这样的……
猜你喜欢
- 2025-03-10 新手必看 | 一学就会!原来web网页布局是这样的……
- 2025-03-10 前端不会消失,前端的你可能会消失
- 2025-03-10 从零开始搭建第一个网页:HTML基础入门
你 发表评论:
欢迎- 614℃几个Oracle空值处理函数 oracle处理null值的函数
- 606℃Oracle分析函数之Lag和Lead()使用
- 594℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 591℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 585℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 579℃【数据统计分析】详解Oracle分组函数之CUBE
- 568℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 559℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- PageHelper - 最方便的 MyBatis 分页插件
- 面试二:pagehelper是怎么实现分页的,
- MyBatis如何实现分页查询?(mybatis-plus分页查询)
- SpringBoot 各种分页查询方式详解(全网最全)
- 如何在Linux上运行exe文件,怎么用linux运行windows软件
- 快速了解hive(快速了解美国50个州)
- Python 中的 pyodbc 库(pydbclib)
- Linux搭建Weblogic集群(linux weblogic部署项目步骤)
- 「DM专栏」DMDSC共享集群之部署(一)——共享存储配置
- 故障分析 | MySQL 派生表优化(mysql pipe)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)