当前位置: 首页 > news >正文

【pyqt5】QLineEdit中的文本输入限制方式,输入校验规则的应用详解

在这里插入图片描述

✨✨ 欢迎大家来到景天科技苑✨✨

🎈🎈 养成好习惯,先赞后看哦~🎈🎈

🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。
🏆《博客》:Python全栈,前后端开发,小程序开发,云原生K8S,人工智能,js逆向,App逆向,网络系统安全,数据分析,PyQt5和tkinter桌面开发,Django,fastapi,flask等框架,linux,shell脚本等实操经验,网站搭建,数据库等分享。

所属的专栏:PyQt5桌面应用开发,零基础到进阶应用实战
景天的主页:景天科技苑

在这里插入图片描述

文章目录

  • PyQt5中QLineEdit的输入检验
    • 一、QLineEdit基础
      • 1. 示例代码:创建基本的QLineEdit
    • 二、文本输入限制
      • 1. 最大长度限制
      • 2. 只读限制
    • 三、校验器(Validator)
      • 1. 校验器类型
      • 2. 示例:限制整数输入
      • 3. 示例:限制浮点数输入
      • 4. 示例:使用正则表达式限制输入
      • 5. 示例:年龄输入范围限制
    • 四、使用掩码(Input Mask)
      • 1. 掩码字符说明
      • 2. 设置掩码方式
      • 3. 示例:IP地址输入掩码
      • 4. 示例:其他类型的掩码
    • 五、总结

PyQt5中QLineEdit的输入检验

在PyQt5开发桌面应用程序时,QLineEdit是一个常用的控件,用于单行文本输入。然而,在实际应用中,经常需要对用户的输入进行校验,以确保数据的正确性和程序的健壮性。本文将结合实际案例,详细介绍PyQt5中QLineEdit的输入检验方法,包括使用校验器(Validator)、掩码(Input Mask)机制。

一、QLineEdit基础

QLineEdit是PyQt5中用于单行文本输入的控件。它允许用户输入和编辑文本,并支持多种样式和验证方式。在使用QLineEdit之前,首先需要导入必要的PyQt5模块,并创建一个QApplication对象来管理应用程序的事件循环。

1. 示例代码:创建基本的QLineEdit

import sys
from PyQt5.QtWidgets import QApplication, QWidget, QLineEdit, QVBoxLayoutclass MyWidget(QWidget):def __init__(self):super().__init__()self.initUI()def initUI(self):self.setWindowTitle('QLineEdit 示例')self.setGeometry(100, 100, 280, 80)layout = QVBoxLayout()self.line_edit = QLineEdit(self)self.line_edit.setPlaceholderText("请输入文本...")layout.addWidget(self.line_edit)self.setLayout(layout)if __name__ == '__main__':app = QApplication(sys.argv)ex = MyWidget()ex.show()sys.exit(app.exec_())

在上述代码中,我们创建了一个包含QLineEdit的简单窗口,并设置了占位符文本。

二、文本输入限制

主要用于作为开发人员,设定限制规则,来限制用户在文本框中输入的内容,比如限制只能输入数字,数字最大长度等等
相关api介绍
在这里插入图片描述

1. 最大长度限制

#设置最长输入限制,最多输入三个字符,再多了输入不进去了
le_login.setMaxLength(3)
在这里插入图片描述

#获取文本框最大输入长度
print(le_login.maxLength())
在这里插入图片描述

2. 只读限制

设置了只读限制,无法修改文本框里面的内容

#设置只读
le_login.setReadOnly(True)
#设置了只读,但是可以通过代码输入内容
le_login.setText(“我来了”)
在这里插入图片描述
但是通过代码设置也不能超越设置的最大长度
在这里插入图片描述

三、校验器(Validator)

1. 校验器类型

通过设定的规则来验证用户输入的内容的合法性
PyQt5提供了多种校验器(Validator)来限制QLineEdit的输入。常用的校验器包括:

  • QIntValidator:用于限制输入为整数。
  • QDoubleValidator:用于限制输入为浮点数。
  • QRegExpValidator:使用正则表达式限制输入。
    在这里插入图片描述
    QValidator是一个抽象类,在实现它的时候,需要子类化此类
    实现两个方法,validate和fix方法

2. 示例:限制整数输入

from PyQt5.QtGui import QIntValidator# 假设line_edit为已经创建的QLineEdit实例
int_validator = QIntValidator()
int_validator.setRange(1, 100)  # 设置整数的范围
line_edit.setValidator(int_validator)

在上述代码中,我们创建了一个QIntValidator实例,并设置了整数的范围为1到100。然后,我们将这个校验器与QLineEdit实例绑定,以限制用户只能输入这个范围内的整数。

3. 示例:限制浮点数输入

from PyQt5.QtGui import QDoubleValidatordouble_validator = QDoubleValidator()
double_validator.setRange(-100.0, 100.0)  # 设置浮点数的范围
double_validator.setNotation(QDoubleValidator.StandardNotation)  # 设置标准显示方式
double_validator.setDecimals(2)  # 设置小数点后的位数
line_edit.setValidator(double_validator)

在上述代码中,我们创建了一个QDoubleValidator实例,并设置了浮点数的范围为-100.0到100.0,同时设置了标准显示方式和小数点后的位数。

4. 示例:使用正则表达式限制输入

from PyQt5.QtGui import QRegExpValidator
from PyQt5.QtCore import QRegExp# 使用正则表达式限制输入为数字或字母
reg_exp = QRegExp("[a-zA-Z0-9]+$")
reg_validator = QRegExpValidator(reg_exp)
line_edit.setValidator(reg_validator)

在上述代码中,我们使用了正则表达式"[a-zA-Z0-9]+$"来限制用户只能输入字母和数字,并将这个正则表达式与QLineEdit实例绑定。

5. 示例:年龄输入范围限制

限制输入年龄的范围是18-180,输入字母校验失败,输入小于18的修正为18

from PyQt5.Qt import *#自定义个类继承QValidator
class AgeVadidator(QValidator):#重写validate和fix方法#validate方法传进去两个参数,一个是字符串,一个是整形,分别代表输入的内容和光标的位置#该方法一定要有返回三个参数,分别是是否验证通过,输入字符串,光标位置def validate(self, input_str, pos_int):print(input_str, pos_int)# 判定# 结果字符串, 应该全部都是由一些数字组成# return的结果中,input_str就是在文本框显示的内容,我们也可以写死,不管用户输入什么都返回固定值,和固定的光标位置#下面代码中有强制类型转换,为了防止报错,我们try一下,只有输入的数数字才能显示try:if 18 <= int(input_str) <= 180:return QValidator.Acceptable, input_str, pos_int#输入1-17之间,暂时不做判断elif 1 <= int(input_str) <= 17:return QValidator.Intermediate, input_str, pos_intelse:return QValidator.Invalid, input_str, pos_intexcept:#当用户还没输入,或者删除所有内容的时候,设为暂不做判定状态if len(input_str) == 0:return QValidator.Intermediate, input_str, pos_int#验证不通过的不会在输入框显示return QValidator.Invalid, input_str, pos_int# fix用来修正数据,当光标离开输入框(结束编辑)之后,根据判断逻辑返回我们设定的值# 用来修复处于暂不做设定状态的值,当用户输入完毕,结束编辑之后,如果输入的内容经过validate验证后处于非有效状态#就会执行fix函数里面的逻辑def fixup(self, p_str):print("xxx", p_str)try:if int(p_str) < 18:return "18"except:return "18"#自定义个类来继承QIntValidator,重写fix方法来做修复
class MyAgeVadidator(QIntValidator):def fixup(self, p_str):print("xxx", p_str)if len(p_str) == 0 or int(p_str) < 18:# if int(p_str) < 18 or len(p_str) == 0:return "18"class Window(QWidget):def __init__(self):super().__init__()self.setWindowTitle("QLineEidt验证器的学习")self.resize(500, 500)self.setup_ui()def setup_ui(self):le = QLineEdit(self)le.move(100, 100)# 18 - 180vadidator = AgeVadidator()# vadidator = QIntValidator(18, 180)# vadidator = MyAgeVadidator(18, 180)#将验证器传到setValidator方法中le.setValidator(vadidator)le2 = QLineEdit(self)le2.move(200, 200)if __name__ == '__main__':import sysapp = QApplication(sys.argv)window = Window()window.show()sys.exit(app.exec_())

当用户输入完1,鼠标光标离开输入框,走fix方法修复,输出18
在这里插入图片描述
当用户输入非数字,不会显示到输入框
在这里插入图片描述
当用户输入12a,鼠标离开,走fix方法,返回18
在这里插入图片描述

四、使用掩码(Input Mask)

除了使用校验器外,PyQt5还提供了掩码(Input Mask)功能来限制QLineEdit的输入。掩码允许你定义输入字段的格式,并在用户输入时自动应用这个格式。
在这里插入图片描述

1. 掩码字符说明

PyQt5的掩码功能支持多种掩码字符,以下是一些常用的掩码字符及其说明:

  • A:ASCII字母字符(大写或小写)是必须输入的(A-Z, a-z)。
  • a:ASCII字母字符(大写或小写)是允许输入的,但不是必需的(A-Z, a-z)。
  • N:ASCII字母数字字符(大写、小写或数字)是必须输入的(A-Z, a-z, 0-9)。
  • n:ASCII字母数字字符(大写、小写或数字)是允许输入的,但不是必需的(A-Z, a-z, 0-9)。
  • X:任何字符都是必须输入的。
  • x:任何字符都是允许输入的,但不是必需的。
  • 9:ASCII数字字符(0-9)是必须输入的。
  • 0:ASCII数字字符(0-9)是允许输入的,但不是必需的。
  • D:ASCII数字字符(1-9)是必须输入的,不允许以0开头。
  • d:ASCII数字字符(1-9)是允许输入的,但不允许以0开头,不是必需的。
  • H:十六进制格式字符(A-F, a-f, 0-9)是必须输入的。
  • h:十六进制格式字符(A-F, a-f, 0-9)是允许输入的,但不是必需的。
  • B:二进制格式字符(0, 1)是必须输入的。
  • b:二进制格式字符(0, 1)是允许输入的,但不是必需的。
  • #:ASCII字符(包括空格)是可以输入的,用于分隔视觉上的元素,不限制输入。
  • >:将所有后续字符转换为大写。
  • <:将所有后续字符转换为小写。
  • !:关闭大小写转换。
  • \:用于转义上面列出的特殊字符。

2. 设置掩码方式

setInputMask(mask_str)
mask_str表示掩码字符串
掩码字符串大致有三部分组成
掩码由一串掩码字符和分隔符组成 + 可选的分号; 和 空白占位字符

3. 示例:IP地址输入掩码


# 0. 导入需要的包和模块
from PyQt5.Qt import *  # 主要包含了我们常用的一些类, 汇总到了一块
import sys# 1. 创建一个应用程序对象
app = QApplication(sys.argv)# 2. 控件的操作
# 2.1 创建控件
window = QWidget()# 2.2 设置控件
#设置窗口标题,默认标题是python,只有顶级控件才可以设置标题栏的标题
window.setWindowTitle("掩码验证")
#设置窗口大小,注意,设置的空间尺寸大小,不包含上面的标题栏
window.resize(500, 500)# le 设置掩码
# 总共输入5 位
# 左边 2(必须是大写字母) - 右边 2(必须是一个数字)
# > 后面跟的字母都是大写字母
#占位符根据掩码字符表查
#分隔符是 -
#两位大写字母,写俩A即可。两位数字,俩9即可
#分号后面是空白占位符,就是没有输入的时候显示的占位符#IP地址 XXX.XXX.XXX.XXX
# 由于ip地址的取值范围是0-255,需要借助输入验证#自定义个类继承QValidator
class PhoneVadidator(QValidator):#重写validate和fix方法#validate方法传进去两个参数,一个是字符串,一个是整形,分别代表输入的内容和光标的位置#该方法一定要有返回三个参数,分别是是否验证通过,输入字符串,光标位置def validate(self, input_str, pos_int):print(input_str.split("."), pos_int)data = input_str.split(".")#每个网段都小于255才能通过校验if int(data[0]) <=255 and int(data[1]) <=255 and  int(data[2])<=255 and int(data[3])<=255:return QValidator.Acceptable, input_str, pos_int#其他的校验失败else:return QValidator.Invalid, input_str, pos_int#ip地址校验
addr = QLineEdit(window)
addr.move(150, 100)
addr.setInputMask("999.999.999.999;0")
vadidator = PhoneVadidator()
addr.setValidator(vadidator)# 2.3 展示控件
window.show()# 3. 应用程序的执行, 进入到消息循环
sys.exit(app.exec_())

在上述代码中,"999.999.999.999;0"是IP地址的输入掩码。其中,9表示必须输入的数字字符,.是IP地址的分隔符,0是占位符,表示在不输入时显示的默认字符(通常是下划线或0,具体取决于平台的实现)。每段的数字最大限制为255。这样,用户就只能按照XXX.XXX.XXX.XXX的格式输入IP地址了。

在这里插入图片描述

4. 示例:其他类型的掩码

  • MAC地址掩码
line_edit.setInputMask("HH:HH:HH:HH:HH:HH;_")

这里H表示十六进制字符(0-9, A-F, a-f),用于MAC地址的输入。

  • 日期掩码
line_edit.setInputMask("0000-00-00")

line_edit.setInputMask("0000-00-00;*")

这里0表示必须输入的数字,用于年月日的输入。*是占位符的另一种表示方式,具体显示可能因平台而异。

  • 许可证号掩码
line_edit.setInputMask(">AAAAA-AAAAA-AAAAA-AAAAA-AAAAA;#")

这里A表示大写字母,>表示将后续字符转换为大写,#是占位符,用于分隔和占位。

五、总结

通过校验器和掩码,PyQt5的QLineEdit控件可以灵活地限制用户的输入,确保数据的正确性和程序的健壮性。在实际开发中,应根据具体需求选择合适的校验方式,并合理设置校验规则或掩码格式。此外,还可以结合信号与槽机制,对用户的输入进行实时监控和处理,进一步提升用户体验和程序的交互性。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 文心快码 Baidu Comate 前端工程师观点分享:以文心快码 Baidu Comate为例,智能代码助手需要什么(一)
  • 《重生到现代之从零开始的C语言生活》—— 指针3
  • 手机运动信息管理系统
  • Oracle(76)如何收集统计信息?
  • 深度解析Python PyInstaller打包EXE的详细教程
  • C#发送邮件功能实现全面指南?有哪些方法?
  • C语言--01基础数据类型
  • 前端使用 Konva 实现可视化设计器(21)- 绘制图形(椭圆)
  • 【设计模式】六大原则-下
  • OpenAI 重回巅峰:ChatGPT-4O 最新模型超越谷歌 Gemini 1.5,多项测试夺冠!
  • C++ | Leetcode C++题解之第355题设计推特
  • QTday04
  • 复现 LET-NET
  • rust api接口开发(以登陆和中间件鉴权为例)
  • 企业高性能web服务器之nginx篇
  • 03Go 类型总结
  • C++回声服务器_9-epoll边缘触发模式版本服务器
  • Eureka 2.0 开源流产,真的对你影响很大吗?
  • iOS | NSProxy
  • Mac转Windows的拯救指南
  • maven工程打包jar以及java jar命令的classpath使用
  • uva 10370 Above Average
  • 从 Android Sample ApiDemos 中学习 android.animation API 的用法
  • 搭建gitbook 和 访问权限认证
  • 对话 CTO〡听神策数据 CTO 曹犟描绘数据分析行业的无限可能
  • 记一次和乔布斯合作最难忘的经历
  • 聊聊sentinel的DegradeSlot
  • 前端技术周刊 2019-01-14:客户端存储
  • 少走弯路,给Java 1~5 年程序员的建议
  • 算法-插入排序
  • MyCAT水平分库
  • Nginx惊现漏洞 百万网站面临“拖库”风险
  • SAP CRM里Lead通过工作流自动创建Opportunity的原理讲解 ...
  • ​软考-高级-系统架构设计师教程(清华第2版)【第12章 信息系统架构设计理论与实践(P420~465)-思维导图】​
  • #{}和${}的区别?
  • #VERDI# 关于如何查看FSM状态机的方法
  • (ISPRS,2021)具有遥感知识图谱的鲁棒深度对齐网络用于零样本和广义零样本遥感图像场景分类
  • (机器学习-深度学习快速入门)第一章第一节:Python环境和数据分析
  • (十五)Flask覆写wsgi_app函数实现自定义中间件
  • (四) 虚拟摄像头vivi体验
  • (转) SpringBoot:使用spring-boot-devtools进行热部署以及不生效的问题解决
  • .NET Entity FrameWork 总结 ,在项目中用处个人感觉不大。适合初级用用,不涉及到与数据库通信。
  • .net 程序 换成 java,NET程序员如何转行为J2EE之java基础上(9)
  • .NET/C# 解压 Zip 文件时出现异常:System.IO.InvalidDataException: 找不到中央目录结尾记录。
  • .NET/C# 项目如何优雅地设置条件编译符号?
  • .NET命名规范和开发约定
  • @Tag和@Operation标签失效问题。SpringDoc 2.2.0(OpenApi 3)和Spring Boot 3.1.1集成
  • [ vulhub漏洞复现篇 ] JBOSS AS 5.x/6.x反序列化远程代码执行漏洞CVE-2017-12149
  • [10] CUDA程序性能的提升 与 流
  • [2017][note]基于空间交叉相位调制的两个连续波在few layer铋Bi中的全光switch——
  • [Angularjs]ng-select和ng-options
  • [ASP.NET MVC]如何定制Numeric属性/字段验证消息
  • [BSGS算法]纯水斐波那契数列
  • [C/C++随笔] char与unsigned char区别
  • [C++]模板与STL简介