Qt QRegExp正则表达式学习及应用
发布时间:2020-12-14 01:25:40 所属栏目:百科 来源:网络整理
导读:Qt的SDK里包含一个很帮的GUI工具,可以方便我们进行这类转换并测试你的表达式。可以按照如下的方式打开:“开始”-“程序”-“Qt SDK by Nokia v2010.02.1 (open source)”-“QtDemo”-“Tools”-“RegularExpression”可以选择“launch”启动程序,亦可以“
QRegExp::QRegExp ( const QRegExp &rx)//建立一个正则表达式,该表达式是rx的复制版
如程序中建立的匹配节点重启的正则表达式QRegExp regexp("TaskCTLL");就是以TaskCTLL为表达式进行匹配。
QRegExp::QRegExp ( constQString&pattern,Qt::CaseSensitivitycs= Qt::CaseSensitive,PatternSyntaxsyntax= RegExp )//根据给定的模式串(pattern string)建立正则表达式对象,模式串必须以通配符(wildcard)的形式给出
如程序中建立的匹配第一父节点的饿正则表达式QRegExp regexpparent("parent[0]s+-{0,1}(d+)b");
int QRegExp::indexIn ( constQString&str,intoffset= 0,CaretModecaretMode= CaretAtZero ) const//企图从位置偏移为零(默认值)出找到一个匹配的字符处str,返回第一个匹配点的位置position,如果没有匹配则返回-1
程序中只需要匹配一次(文本文件中每一行只有一个不重复的str),只要匹配成功返回值不是-1,就对信息进行提取保存
Qt里的正则表达式和C++里面的有些差别,例如.表示. d表示d
程序实例:
匹配时钟跳变
2011/06/27 22:05:42.011 parent[1] -1
2011/06/27 22:05:42.011 Local time 2d5820d
":(d+).(d+)s+(w*s*w*s*d*,s*)*(w*s*)*(parent[[01]]s+-{0,1}d+)*(w*d*.d*w*s*d*)*Locals+time"
匹配第一父节点
2011/06/27 22:05:42.011 parent[0] 6003
"parent[0]s+-{0,1}(d+)b"
匹配节点号
2011/06/27 22:26:30.090 mac neigh 0,addr 100
"macs+neighs+0,s+addrs+(d+)b"
根节点收到数据
2011/06/27 22:07:45.058 ROOT receive data origin 52 100
"ROOTs+receives+dadas+origins+(d+)s+(d+)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之间的任意字符
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |