Qt通过正则表达式筛选出字符串中的手机号

需求

用户需要聊天记录中含有11位的手机号码进行提醒的功能,所以需要在收到聊天消息后匹配查看是否存在手机号。如果找到然后提醒。

分析

主要的需求可以拆分为两点:

  1. 筛选出字符串里面的数字字符。
  2. 通过正则匹配数字字符是否是11位手机号码。
    一开始没有进行筛选数字字符串的动作,而仅仅通过正则表达式查找11位手机号。发现像嘻嘻138830978901333五 这样超过11位的数字字符也能被匹配后。
    后面先筛选数字字符串,然后再去正则匹配。

代码实现

一、筛选字符串里面的数字字符

在Qt Assistant中查找QRegExp里面有一个demo可以通过正则表达式筛选字符串中的数字字符,通过一个循环保存到QStringList里面。

cpp 复制代码
 QRegExp rx("(\\d+)");
 QString str = "Offsets: 12 14 99 231 7";
 QStringList list;
 int pos = 0;

 while ((pos = rx.indexIn(str, pos)) != -1) {
     list << rx.cap(1);
     pos += rx.matchedLength();
 }
 // list: ["12", "14", "99", "231", "7"] 

二、通过正则匹配是否是11位手机号

通过查看手机号的号段和对应的规则,写了如下的正则表达式:

复制代码
^1([358][0-9]|4[579]|6[2567]|7[0135678]|9[0123589])[0-9]{8}$

参考如下两篇文章:

  1. Qt判断手机号码:匹配手机号码的正则
  2. 最新最全的手机号验证正则表达式
    后面封装函数如下:
cpp 复制代码
bool HasPhoneNum(const QString& strNum)
{
    QRegExp rx("\\d+");
    QRegExp regx("^1([358][0-9]|4[579]|6[2567]|7[0135678]|9[0123589])[0-9]{8}$");
    QRegExpValidator regs(regx,0);
    QString d;
    int pos = 0;
    int nPos = 0;

    while ((pos = rx.indexIn(strNum, pos)) != -1) {
        QString strPhone = rx.cap(0);
        QValidator::State res = regs.validate(strPhone, nPos);
        if (QValidator::Acceptable == res) {
            return true;
        }
        pos += rx.matchedLength();
    }

    return false;
}
相关推荐
你我约定有三1 小时前
分布式微服务--万字详解 微服务的各种负载均衡全场景以注意点
java·开发语言·windows·分布式·微服务·架构·负载均衡
机器视觉知识推荐、就业指导3 小时前
手动开发一个TCP客户端调试工具(一):了解Qt中TCP通信原理与核心类
网络·qt·tcp/ip
归云鹤6 小时前
QT信号和槽怎么传输自己定义的数据结构
开发语言·数据结构·qt
程序视点7 小时前
电脑硬件检测必备!图吧工具箱11年免费良心软件!100+免费工具合集
前端·windows·后端
cpp_learners7 小时前
QT Word模板 + QuaZIP + LibreOffice,跨平台方案实现导出.docx文件后再转为.pdf文件
qt·pdf·docx
云心雨禅9 小时前
修改Windows鼠标滚轮方向
windows·计算机外设
程序视点9 小时前
2025最佳Windows优化工具推荐:292KB小工具解决Win11右键菜单/自动更新/Defender等12大痛点
windows·性能优化
SHUIPING_YANG11 小时前
windows软件ARM64和AMD64(x64)区别,如何查看电脑支持哪种
windows·电脑
程序员编程指南12 小时前
Qt 移动应用发布与分发指南
c语言·开发语言·c++·qt
x晕x12 小时前
Qt 消息弹窗 Toast
linux·c++·windows·qt·mac