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"

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

相关推荐
咖啡Beans43 分钟前
MySQL中使用@符号定义用户变量
数据库·mysql
_凌凌漆_2 小时前
【Qt】Qt中对MVC,MVP的理解
qt
知其然亦知其所以然2 小时前
MySQL 社招必考题:如何优化特定类型的查询语句?
后端·mysql·面试
粘豆煮包5 小时前
掀起你的盖头来之《数据库揭秘》-3-SQL 核心技能速成笔记-查询、过滤、排序、分组等
后端·mysql
DemonAvenger7 小时前
MySQL海量数据快速导入导出技巧:从实战到优化
数据库·mysql·性能优化
程序新视界19 小时前
MySQL中什么是回表查询,如何避免和优化?
mysql
得物技术1 天前
破解gh-ost变更导致MySQL表膨胀之谜|得物技术
数据库·后端·mysql
Java水解1 天前
【MySQL】从零开始学习MySQL:基础与安装指南
后端·mysql
沢田纲吉1 天前
🗄️ MySQL 表操作全面指南
数据库·后端·mysql
Java水解2 天前
Mysql查看执行计划、explain关键字详解(超详细)
后端·mysql