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;
}
相关推荐
小小码农Come on5 小时前
QT实现线程4种方法
qt
jf加菲猫8 小时前
第15章 文件和目录
开发语言·c++·qt·ui
CyL_Cly8 小时前
杀戮尖塔2mod:二次元猎宝
windows·游戏
不做菜鸟的网工11 小时前
Windows WSL 使用技巧
windows
heimeiyingwang13 小时前
【架构实战】Event Sourcing事件溯源详解
windows·架构
少控科技13 小时前
小数典 - V1.0.0.1
windows·c#
清风玉骨13 小时前
C++/Qt从零开始编译使用libxlsxwriter库
开发语言·qt
遇见火星14 小时前
Firewalld 防火墙实战指南 + TCPWrapper 七层访问控制
开发语言·windows·python
jingshaoqi_ccc14 小时前
使用QT6创建一个可编辑的表格并导出和载入
c++·qt·表格
eastyuxiao15 小时前
MMM 工具一键去水印+检测 批处理脚本(Windows/Mac 双版本)
人工智能·windows·macos·ai音乐去水印