1. 常用正则表达式
表达式 |
说明 |
r,n |
代表回车和换行符 |
t |
制表符 |
|
代表 "" 本身 |
^ |
匹配 ^ 符号本身 |
$ |
匹配 $ 符号本身 |
元字符 |
说明 |
. |
匹配除了换行符以外的任意字符 |
w |
匹配字母、数字、下划线、汉字 |
s |
匹配任意的空白符 |
b |
单词的开始或结尾 |
~ |
匹配字符串的开始 |
$ |
匹配字符串的结束 |
如:
baw*b :匹配以字母a开头的单词——先是某个单词开始处(b),然后是字母a,然后是任意数量的字母或数字(w*),最后是单词结束处(b)。
d+ :匹配1个或更多连续的数字。这里的+是和*类似的元字符,不同的是*匹配重复任意次(可能是0次),而+则匹配重复1次或更多次。
bw{6}b: 匹配刚好6个字符的单词。
表达式 |
说明 |
[ ] |
包含一系列字符 |
[^ ] |
包含之外一系列字符 |
|
|
[ab5@]: 匹配 "a" 或 "b" 或 "5" 或 "@"
[^abc]: 包含abc之外的任意字符
[f-k]: f-k之间的任意字符
表达式 |
说明 |
{n} |
表达式重复n次,比如:"w{2}" 相当于 "ww";"a{5}" 相当于 "aaaaa" |
{m,n} |
表达式至少重复m次,最多重复n次,比如:"ba{1,3}"可以匹配 "ba"或"baa"或"baaa |
{m,} |
表达式至少重复m次,比如:"wd{2,}"可以匹配 "a12","_456","M12344"... |
? |
匹配表达式0次或者1次,相当于 {0,1},比如:"a[cd]?"可以匹配 "a","ac","ad" |
+ |
表达式至少出现1次,相当于 {1,},比如:"a+b"可以匹配 "ab","aab","aaab"... |
* |
表达式不出现或出现任意次,相当于 {0,},比如:"^*b"可以匹配 "b","^^^b"... |
2.Qt 中使用正则表达式
Qt 用QRegExp 来封装正则表达式。如: QRegExp rx("^[0-9]+(.d+)?$");
例如我们又这个一个有规则的字符串:价格:数量:商家编码:属性名:属性值;属性名:属性值; 价格:数量:商家编码:属性名:属性值;属性名:属性值;属性名:属性值; 价格:数量:商家编码:属性名:属性值;
想要分成:
价格:数量:商家编码:属性名:属性值;属性名:属性值;
价格:数量:商家编码:属性名:属性值;属性名:属性值;属性名:属性值;
价格:数量:商家编码:属性名:属性值;
首先选择合适的正则表达式:(w*:){3}(w*:w*;)+, 然后:
1 QRegExp rx(tr("(w*:){3}(w*:w*;)+"));
2 int pos(0);
3
4 while ((pos = rx.indexIn(str,pos)) != -1)
5 {
6 strList.push_back(rx.capturedTexts().at(0));
7 pos += rx.matchedLength();
8 }
3、QRegExp类的构造函数
- 默认构造函数,QRegExp(),产生一个空的正则表达式对象。
- 拷贝构造函数,QRegExp(const QRegExp& patten)
- 模式构造函数,QRegExp ( const QString & pattern,Qt::CaseSensitivity cs = Qt::CaseSensitive,PatternSyntax syntax = RegExp),产生指定匹配模式的正则表达式对象。
4、可以获得正则表达式对象的信息和匹配信息
1) isValid(),判断正则表达式是否合法,合法返回true,否则返回false。
例如:QRegExp exp1("c[9]");
bool valid=exp1.isValid();//返回true
QRegExp exp1("c[9");
bool valid=exp1.isValid();//返回false
2)errorString()
检查正则是否有错误,和isValid类似,当有错误时返回"no error occurred",无错误返回"unexpected end"
3)isEmpty(),判断正则是否为空,当采用默认构造函数生成正则时,此函数返回true,否则返回false。
e.g. QRegExp exp1;
bool valid=exp1.isEmpty();//返回true
4) caseSensitivity () 看正则是否大小写敏感。
5) cap(),capturedTexts () 前者获得捕捉的每一项,index从1开始,后者则获得整个捕捉列表。
6) exactMatch(QString),返回是否整串匹配,匹配一部分也返回false。
7) indexIn(),进行匹配,如果成功则返回index,不成功返回-1
8) matchedLength(),返回匹配的串的长度。
9) numCaptures(),获得正则里捕捉项的个数。
10) pattern(),获得正则本身
11) patternSyntax()
enum PatternSyntax { RegExp,RegExp2,Wildcard,FixedString } 默认为RegExp。
5、举例
QRegExp rx;
rx.setPatternSyntax(QRegExp::RegExp);
rx.setCaseSensitivity(Qt::CaseSensitive); //大小写敏感
rx.setPattern(QString("^[A-Za-z0-9]+$")); //匹配所有大小写字母和数字组成的字符串
QString s = "dsada@";
rx.exactMatch(s); //返回的值为false,因为s中含有@字符
(编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|