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;
}
相关推荐
x***r1511 小时前
node-v0.12.2-x86安装步骤详解(附Node.js历史版本与32位配置教程)
windows
小小小米粒1 小时前
Collection单列集合、Map(Key - Value)双列集合,多继承实现。
java·开发语言·windows
蜡台2 小时前
Python包管理工具pip完全指南-----2
linux·windows·python
小短腿的代码世界3 小时前
Qt文件系统与IO深度解析:从QFile到异步文件操作
开发语言·qt
徐某人..6 小时前
基于i.MX6ULL平台的智能网关系统开发
arm开发·c++·单片机·qt·物联网·学习·arm
love530love7 小时前
Windows Podman Machine 虚拟硬盘迁移完整指南:从 C 盘到非系统盘
c语言·人工智能·windows·podman
love530love7 小时前
Podman Machine 虚拟硬盘迁移实战二:用 Junction 把 vhdx 从 C 盘搬到其他盘
c语言·开发语言·人工智能·windows·wsl·podman·podman machine
(Charon)8 小时前
【C++/Qt】Qt 封装 TCP 客户端底层 Network 类:连接、收发、自动测试与错误处理
服务器·网络·qt·tcp/ip
薛定猫AI9 小时前
【技术干货】Claude Code 终端编程实战:从零搭建 Windows 高效 AI 开发环境
人工智能·windows