Qt中正则表达式的用法

一.基本功能介绍:

在Qt中,可以使用QRegularExpression类来处理正则表达式。以下是一些常用的正则表达式用法:

1.创建正则表达式对象:

cpp 复制代码
QRegularExpression regex("pattern");

2.匹配字符串:

cpp 复制代码
QString str = "Hello, World!";
if (regex.match(str).hasMatch()) {
    qDebug() << "Match found!";
} else {
    qDebug() << "No match found!";
}

3.捕获匹配的内容:

cpp 复制代码
QRegularExpressionMatch match = regex.match(str);
if (match.hasMatch()) {
    qDebug() << "Captured text: " << match.captured();
}

4.替换匹配的内容:

cpp 复制代码
QString replacedStr = regex.replace(str, "replacement");

5.检测是否匹配:

cpp 复制代码
if (regex.isValid()) {
    qDebug() << "Valid regex pattern!";
} else {
    qDebug() << "Invalid regex pattern!";
}

6.使用捕获组:

cpp 复制代码
QRegularExpression regex("(\\d+):(\\w+)");
QString str = "123:abc";
QRegularExpressionMatch match = regex.match(str);
if (match.hasMatch()) {
    qDebug() << "Number: " << match.captured(1);
    qDebug() << "Text: " << match.captured(2);
}

二.写法介绍

2.1:匹配的示例

当使用正则表达式时,可以根据具体的需求和匹配规则来编写不同的正则表达式模式。以下是一些常见的正则表达式写法示例:

  1. 匹配数字:\d+

    • 示例:匹配一个或多个数字,例如:"123", "4567"等。
  2. 匹配字母:[a-zA-Z]+

    • 示例:匹配一个或多个字母,不区分大小写,例如:"abc", "XYZ"等。
  3. 匹配邮箱地址:\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+.[A-Z|a-z]{2,}\b

  4. 匹配URL:(http|https)://([\w-]+.)+[\w-]+(/[\w-./?%&=]*)?

  5. 匹配手机号码:1\d{10}

    • 示例:匹配中国大陆手机号码格式,以1开头,共11位数字,例如:"13912345678", "18888888888"等。

2.2:相关符号介绍

在正则表达式中,*、?、+、{n} 等符号被称为量词,用于指定匹配模式中前面字符的重复次数或出现情况。下面详细介绍一些常用的量词及其作用:

  1. *(星号):表示匹配前面的字符零次或多次。

    • 示例:ab* 可以匹配 "a", "ab", "abb", "abbb" 等。
  2. +(加号):表示匹配前面的字符至少一次或多次。

    • 示例:ab+ 可以匹配 "ab", "abb", "abbb" 等,但不能匹配 "a"。
  3. ?(问号):表示匹配前面的字符零次或一次,即可选匹配。

    • 示例:ab? 可以匹配 "a", "ab",但不能匹配 "abb"。
  4. {n}:表示匹配前面的字符恰好 n 次。

    • 示例:a{3} 可以匹配 "aaa",但不能匹配 "aa" 或 "aaaa"。
  5. {n,}:表示匹配前面的字符至少 n 次。

    • 示例:a{2,} 可以匹配 "aa", "aaa", "aaaa" 等。
  6. {n,m}:表示匹配前面的字符至少 n 次,最多 m 次。

    • 示例:a{2,4} 可以匹配 "aa", "aaa", "aaaa",但不能匹配 "a" 或 "aaaaa"。

这些量词可以用于控制匹配模式中字符重复次数的范围,使得正则表达式更加灵活和精确。在实际应用中,根据具体的匹配需求和规则,可以灵活运用这些量词来构建符合要求的正则表达式模式。

三.复杂样例分析

对^[a-zA-Z][\\w]{5,17}@([A-Za-z0-9\\-]+\\.)+[A-Za-z]{2,6}$进行分析

这个表达式是用来匹配电子邮件地址的。解读如下:

  • ^ 表示匹配输入字符串的开始位置
  • a-zA-Z\] 表示第一个字符必须是字母,不区分大小写

  • @ 表示匹配@符号
  • ([A-Za-Z0-9]+\\.)+ 表示匹配域名部分,可以包含字母、数字和短横线,且必须以点号结尾,且可以重复多次
  • A-Za-z\]{2,6} 表示匹配顶级域名,可以是2到6个字母

因此,这个表达式可以匹配形如"[email protected]"的电子邮件地址。

相关推荐
凤年徐32 分钟前
【数据结构初阶】单链表
c语言·开发语言·数据结构·c++·经验分享·笔记·链表
oioihoii34 分钟前
C++11 右值引用:从入门到精通
开发语言·c++
木子.李3474 小时前
排序算法总结(C++)
c++·算法·排序算法
freyazzr6 小时前
C++八股 | Day2 | atom/函数指针/指针函数/struct、Class/静态局部变量、局部变量、全局变量/强制类型转换
c++
fpcc6 小时前
跟我学c++中级篇——理解类型推导和C++不同版本的支持
开发语言·c++
终焉代码7 小时前
STL解析——list的使用
开发语言·c++
DevangLic7 小时前
【 *p取出内容 &a得到地址】
c++
鑫鑫向栄8 小时前
[蓝桥杯]修改数组
数据结构·c++·算法·蓝桥杯·动态规划
鑫鑫向栄8 小时前
[蓝桥杯]带分数
数据结构·c++·算法·职场和发展·蓝桥杯
m0_552200828 小时前
《UE5_C++多人TPS完整教程》学习笔记37 ——《P38 变量复制(Variable Replication)》
c++·游戏·ue5