Qt正则表达式运用---QRegExp

文章目录

1.匹配数字

1.1个位数

cpp 复制代码
    QString str= "0 1 2 23  10 20 ¥24 #0 @44 111 22- 123 58 99   ";
    QRegExp rx("\\b\\d{1}\\b");
    int index=0;
    while(rx.indexIn(str,index) != -1)
    {

        index = str.indexOf(rx.cap(),index) + rx.matchedLength();
        qDebug()<<rx.cap()<<"index="<<index<<"len"<<rx.matchedLength();

    }

执行结果

cpp 复制代码
"0" index= 1 len 1
"1" index= 3 len 1
"2" index= 5 len 1
"0" index= 12 len 1
"0" index= 15 len 1
"0" index= 22 len 1

这个方法有个弊端就是 10 20 这种两位数里面的0 也会被匹配出来,这个我也不知道是为什么?特殊情况特殊处理就行了。

但是如果是写成 QRegExp rx("^\\d{1}$");形式就可以精准匹配"0"."1","2","3"..."9"的字符串了,不会匹配"10"里面的0了。

1.2两位数 及多位数

cpp 复制代码
	str="0 1 2 23 01 10 20 ¥24 #0 @44 111 22- 123 58 99   "
    QRegExp rx("\\b\\d{2}\\b");

这个可以匹配两位数字

输出如下:

cpp 复制代码
"23" index= 8 len 2
"01" index= 11 len 2
"10" index= 14 len 2
"20" index= 17 len 2
"24" index= 21 len 2
"44" index= 28 len 2
"11" index= 31 len 2
"22" index= 35 len 2
"12" index= 39 len 2
"58" index= 43 len 2
"99" index= 46 len 2

如果想匹配出两位数10 -99 的数 可以这样写 QRegExp rx("\\b[1-9][0-9]\\b");

如果想匹配 1-99的数 可以写成QRegExp rx("\\b[1-9][0-9]?\\b");这个表示第一个数字是1到九之间的,第二个数字是零到九之间的,问号表示第二个数字可以有也可以没有。

如果想匹配出 10-999的数 :可以写成QRegExp rx("\\b[1-9]\\d\\d?\\b");这里的\d表示的就是[0-9]中的一个数

匹配多位数 QRegExp rx("\\b[1-9]\\d{n}\\b");n=1:匹配两位数,n=2:匹配三位数,n=3:匹配四位数。

1.3 匹配非数字

cpp 复制代码
QString str= "0 1 2 23  10 20 ¥24 #0 @44 111 22- 123 58 99   ";
QRegExp rx1("[^0-9]");
QRegExp rx2("[^0-9|\\s]");

rx1就可以匹配出非数字的符号,[^0-9]:表示不匹配0-9的数字。rx2可以匹配出除了数字和空格以外的字符。

匹配单词

cpp 复制代码
QString str = "Hello world! This is a sample text.";
QRegExp rx("\\b\\w+\\b");
int pos = 0;
while ((pos = rx.indexIn(str, pos)) != -1) {
    qDebug() << rx.cap(0);
    pos += rx.matchedLength();
}

输出

cpp 复制代码
"Hello"
"world"
"This"
"is"
"a"
"sample"
"text"

用法都差不多,主要是具体情况具体处理,后续再完善...

相关推荐
用户8307196840822 天前
Java 告别繁琐数据统计代码!MySQL 8 窗口函数真香
java·sql·mysql
stark张宇2 天前
MySQL 核心内幕:从索引原理、字段选型到日志机制与外键约束,一篇打通数据库任督二脉
数据库·mysql·架构
Hoffer_3 天前
MySQL 强制索引:USE/FORCE INDEX 用法与避坑
后端·mysql
Hoffer_3 天前
MySQL 索引核心操作:CREATE/DROP/SHOW
后端·mysql
0xDevNull5 天前
MySQL索引进阶用法
后端·mysql
0xDevNull5 天前
MySQL索引用法
mysql
Felix_One5 天前
Qt 串口通信避坑指南:QSerialPort 的 5 个常见问题
qt
程序员小崔日记5 天前
一篇文章彻底搞懂 MySQL 和 Redis:原理、区别、项目用法全解析(建议收藏)
redis·mysql·项目实战
武子康5 天前
大数据-241 离线数仓 - 实战:电商核心交易数据模型与 MySQL 源表设计(订单/商品/品类/店铺/支付)
大数据·后端·mysql
用户8307196840826 天前
MySQL 查询优化 30 条封神技巧:用好索引,少耗资源,查询快到飞起
mysql