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

Qt输入数据验证的方法

Qt输入数据验证的方法

  • 一、Qt输入数据验证
  • 二、Qt输入数据验证的方法
    • 1、数字输入验证
    • 2、字符串输入验证
      • QValidator 验证器
      • 使用正则表达式
      • 自定义验证逻辑
      • 信号与槽机制
  • 三、验证反馈
  • 四、总结
  • 五、实战
    • 1、效果查看
    • 2、源码分享

一、Qt输入数据验证

  • 在Qt中,输入数据验证可以通过多种方式实现,主要涉及QValidator类、正则表达式、信号与槽机制以及自定义验证逻辑。以下是几种常见的验证方法。
  • 在软件开发中,用户输入数据的验证是一项至关重要的任务。不正确的输入可能导致程序崩溃、数据损坏或安全漏洞。Qt提供了一系列强大的工具来帮助开发者有效地验证和过滤用户输入。

二、Qt输入数据验证的方法

1、数字输入验证

对于数字输入,Qt提供了专门的控件来简化验证过程:
QSpinBox 和 QDoubleSpinBox

// 创建一个整数输入框,范围0-100
QSpinBox *spinBox = new QSpinBox(this);
spinBox->setRange(0, 100);
spinBox->setSingleStep(1);
spinBox->setValue(50);// 创建一个浮点数输入框,范围0.0-1.0
QDoubleSpinBox *doubleSpinBox = new QDoubleSpinBox(this);
doubleSpinBox->setRange(0.0, 1.0);
doubleSpinBox->setSingleStep(0.1);
doubleSpinBox->setValue(0.5);

日期和时间输入

// 日期输入
QDateEdit *dateEdit = new QDateEdit(QDate::currentDate(), this);
dateEdit->setDisplayFormat("yyyy-MM-dd");
dateEdit->setCalendarPopup(true);// 时间输入
QTimeEdit *timeEdit = new QTimeEdit(QTime::currentTime(), this);
timeEdit->setDisplayFormat("hh:mm:ss");

2、字符串输入验证

对于字符串输入,Qt提供了验证器(Validator)和输入掩码(Input Mask)两种主要方式。

QValidator 验证器

Qt提供了QValidator类及其子类(如QIntValidator、QDoubleValidator、QRegularExpressionValidator )来验证输入内容。这些验证器可以直接应用于QLineEdit等输入控件。

// 整数验证器
QLineEdit *intEdit = new QLineEdit(this);
QIntValidator *intValidator = new QIntValidator(0, 100, this);
intEdit->setValidator(intValidator);// 浮点数验证器
QLineEdit *doubleEdit = new QLineEdit(this);
QDoubleValidator *doubleValidator = new QDoubleValidator(0.0, 1.0, 2, this);
doubleValidator->setNotation(QDoubleValidator::StandardNotation);
doubleEdit->setValidator(doubleValidator);// 正则表达式验证器 - 验证电子邮件格式
QLineEdit *emailEdit = new QLineEdit(this);
QRegularExpressionValidator *emailValidator = new QRegularExpressionValidator(QRegularExpression("\\b[A-Z0-9._%+-]+@[A-Z0-9.-]+\\.[A-Z]{2,}\\b", QRegularExpression::CaseInsensitiveOption), this);
emailEdit->setValidator(emailValidator);

使用正则表达式

QRegularExpressionValidator 允许通过正则表达式进行更灵活的验证。例如,验证电子邮件格式:

QLineEdit *emailEdit = new QLineEdit();
QRegExp rx("[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,4}");
QRegularExpressionValidator *validator = new QRegularExpressionValidator (rx, emailEdit);
emailEdit->setValidator(validator);

正则表达式[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,4}匹配常见的电子邮件格式。

自定义验证逻辑

对于复杂验证需求,可以继承QValidator并重写validate方法。例如,验证密码强度:

class PasswordValidator : public QValidator {
public:State validate(QString &input, int &pos) const override {if (input.length() < 8) {return Intermediate;}if (!input.contains(QRegExp("[A-Z]")) || !input.contains(QRegExp("[0-9]"))) {return Intermediate;}return Acceptable;}
};QLineEdit *passwordEdit = new QLineEdit();
passwordEdit->setValidator(new PasswordValidator());

此验证器要求密码长度至少为8个字符,且包含至少一个大写字母和一个数字。

信号与槽机制

通过连接输入控件的信号(如textChanged)到自定义槽函数,可以实现实时验证。例如:

QLineEdit *userEdit = new QLineEdit();
QObject::connect(userEdit, &QLineEdit::textChanged, [userEdit](const QString &text) {if (text.contains(" ")) {userEdit->setStyleSheet("background-color: #FFC0C0;");} else {userEdit->setStyleSheet("");}
});

这段代码检查输入是否包含空格,并通过背景色变化提供视觉反馈。

三、验证反馈

验证反馈在Qt中通常用于表单输入验证,确保用户输入的数据符合预期。Qt提供了多种机制来实现验证反馈,包括QValidator类和样式表定制。

// 设置验证反馈样式
QLineEdit *validatedEdit = new QLineEdit(this);
validatedEdit->setValidator(new QIntValidator(0, 100, this));// 连接textChanged信号来提供实时反馈
connect(validatedEdit, &QLineEdit::textChanged, [validatedEdit](){QString text = validatedEdit->text();int pos = 0;QValidator::State state = validatedEdit->validator()->validate(text, pos);if (state == QValidator::Acceptable) {validatedEdit->setStyleSheet("QLineEdit { background-color: #DFF0D8; }");} elseif (state == QValidator::Intermediate) {validatedEdit->setStyleSheet("QLineEdit { background-color: #FCF8E3; }");} else {validatedEdit->setStyleSheet("QLineEdit { background-color: #F2DEDE; }");}
});

四、总结

Qt提供了多种强大的输入验证工具,包括:

  • 专用输入控件(QSpinBox, QDateEdit等)
  • 验证器(QIntValidator, QDoubleValidator, QRegularExpressionValidator)
  • 输入掩码
  • 自定义验证器

在实际开发中,应根据具体需求选择合适的验证方式,并考虑提供良好的用户反馈,使验证过程既严格又友好。

五、实战

1、效果查看

在这里插入图片描述

2、源码分享

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QValidator>
#include <QRegularExpression>class PasswordValidator : public QValidator {
public:State validate(QString &input, int &pos) const override {qDebug()<<"input:"<<input;if (input.length() < 8) {return Intermediate;}if (!input.contains(QRegularExpression("[A-Z]")) || !input.contains(QRegularExpression("[0-9]"))) {return Invalid;}return Acceptable;}
};MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{ui->setupUi(this);this->ui->lineEdit->setValidator(new PasswordValidator());
}MainWindow::~MainWindow()
{delete ui;
}

在这里插入图片描述

http://www.lryc.cn/news/573416.html

相关文章:

  • rent8_wechat-最常用出租屋管理系统-微信小程序
  • 从零开发ComfyUI插件:打造你的AI绘画专属工具
  • 私有规则库:企业合规与安全的终极防线
  • C# 将 Enum枚举转成List,并显示在下拉列表中
  • LINUX621 NFS 同步 ;FTP;samba环境
  • 面试题-ts中的typeof
  • 面试题-把类型为b的值赋给类型为a的变量
  • Laravel 项目中图片上传后无法访问的问题
  • SQL关键字三分钟入门:INSERT INTO —— 插入数据详解
  • Python实现MySQL建表语句转换成Clickhouse SQL
  • 【格与代数系统】偏序关系、偏序集与全序集
  • 2048小游戏C++板来啦!
  • 【Docker基础】Docker镜像管理:docker rmi、prune详解
  • 竞业限制协议能单独充当商业秘密的 “保护伞” 吗?
  • docker执行yum报错Could not resolve host: mirrorlist.centos.org
  • python web开发-Flask 蓝图(Blueprints)完全指南
  • 【Docker 08】Compose - 容器编排
  • C#测试调用EPPlus根据批注设置excel单元格内容
  • JavaEE初阶第三期:解锁多线程,从 “单车道” 到 “高速公路” 的编程升级(一)
  • 【开源项目】当大模型推理遇上“性能刺客”:LMCache 实测手记
  • linux安装minio并使用
  • 在Docker、KVM、K8S常见主要命令以及在Centos7.9中部署的关键步骤学习备存
  • XCUITest + Objective-C 详细示例
  • FastGPT:开启大模型应用新时代(4/6)
  • Springboot 配置 FastJson 替换 Jackson
  • Rabbitmq集成springboot,手动确认消息basicAck、basicNack、basicReject的使用
  • 在 MyBatis 的xml中,什么时候大于号和小于号可以不用转义
  • Axios 在 Vue3 项目中的使用:从安装到组件中的使用
  • 升级到 .NET 9 分步指南
  • “最浅”的陷阱:聊聊二叉树最小深度的递归坑点与解法哲学