引用http://www.cnblogs.com/sld666666/archive/2011/03/16/1985715.html
1. 常用正则表达式
表达式
说明
\r, \n
代表回车和换行符
\t
制表符
\\
代表 "\" 本身
\^
匹配 ^ 符号本身
\$
匹配 $ 符号本身
元字符
说明
.
匹配除了换行符以外的任意字符
\w
匹配字母、数字、下划线、汉字
\s
匹配任意的空白符
\b
单词的开始或结尾
\~
匹配字符串的开始
$
匹配字符串的结束
如:
\ba\w*\b :匹配以字母a开头的单词——先是某个单词开始处(\b),然后是字母a,然后是任意数量的字母或数字(\w*),最后是单词结束处(\b)。
\d+ :匹配1个或更多连续的数字。这里的+是和*类似的元字符,不同的是*匹配重复任意次(可能是0次),而+则匹配重复1次或更多次。
\b\w{6}\b: 匹配刚好6个字符的单词。
表达式
说明
[ ]
包含一系列字符
[^ ]
包含之外一系列字符
[[email protected]]: 匹配 "a" 或 "b" 或 "5" 或 "@"
[^abc]: 包含abc之外的任意字符
[f-k]: f-k之间的任意字符
2.Qt 中使用正则表达式
Qt 用QRegExp 来封装正则表达式。如: QRegExp rx("^[0-9]+(\\.\\d+)?$");
例如我们又这个一个有规则的字符串:价格:数量:商家编码:属性名:属性值;属性名:属性值; 价格:数量:商家编码:属性名:属性值;属性名:属性值;属性名:属性值; 价格:数量:商家编码:属性名:属性值;
想要分成:
价格:数量:商家编码:属性名:属性值;属性名:属性值;
价格:数量:商家编码:属性名:属性值;属性名:属性值;属性名:属性值;
价格:数量:商家编码:属性名:属性值;
首先选择合适的正则表达式:(\w*:){3}(\w*:\w*;)+, 然后:
QRegExp rx(tr("(\\w*:){3}(\\w*:\\w*;)+"));
int pos(0);
while ((pos = rx.indexIn(str, pos)) != -1)
{
strList.push_back(rx.capturedTexts().at(0));
pos += rx.matchedLength();
}
strList 就是想要的结果了