首先看几个例子:
QRegexp rx("^-?(180|([1-9]?[0-9]|1[0-7][0-9])(\\.\\d)?)$");
QRegExpValidator *pReg = new QRegExpValidator(rx, this);
lineEdit->setValidator(pReg);
2.限制浮点数输入范围为[-180,180]并限定为小数位后4位
QRegExp rx("^-?(180|([1-9]?[0-9]|1[0-7][0-9])(\\.\\d{1,4})?)$");
QRegExpValidator *pReg = new QRegExpValidator(rx, this);
lineEdit->setValidator(pReg);
3.限制浮点数输入范围为[-90,90]并限定为小数位后4位
QRegExp rx("^-?(90|[1-8]?\\d(\\.\\d{1,4})?)$");
QRegExpValidator *pReg = new QRegExpValidator(rx, this);
lineEdit->setValidator(pReg);
简答说下这几个正则表达式:1. 限制浮点数输入范围为[-180,180]
^-?(180|([1-9]?\d|1[0-7][0-9])(\.\d)?)$ 或者也可以写成 ^-?(180|([1-9]?[0-9]|1[0-7][0-9])(\.[0-9])?)$
2.限制浮点数输入范围为[-180,180]并限定为小数位后4位
^-?(180|([1-9]?\d|1[0-7][0-9])(\.\d{1,4})?)$ 或者也可以写成 ^-?(180|([1-9]?[0-9]|1[0-7][0-9])(\.[0-9]{1,4})?)$
3.限制浮点数输入范围为[-90,90]并限定为小数位后4位
^-?(90|[1-8]?\d(\.\d{1,4})?)$
1.式子中开头的^和结尾的$限定字符串的开始和结尾;
2."-?" 表示一个或0个负号,这里面的问号表示其前面的字符重复0次或1次;
3.管道符“|”表示平行分组,表示180或其它形式;
4.[1-9] 表示限定数字范围为1到9,其余类似,如果是有限几个值,还可以用枚举的方式,比如限定-255到255时,第一个数字2的限定,应该表达为[1,2],这表示这个位置只允许是1或者2;
5."\d"是一个转义字符,表示匹配一位数字(0到9);
6.“\.” 表示匹配小数点;
7."\d+",这里面的+表示其前面的\d重复一次或多次;
8."\d{1,4}",里面的{1,4}表示重复1到4次;
有了以上知识,下面我们可以很快的写出限定[-255,255]的正则表达式:
[-255,255]整数:^-?(255|[1-9]?[0-9]|[1,2][0-5][0-4])$
[-255,255]小数:^-?(255|[1-9]?[0-9]|[1,2][0-5][0-4])(\.\d)?)$
下面是QT的常用的正则表达式:
表达式 | 说明 |
\r, \n | 代表回车和换行符 |
\t | 制表符 |
\\ | 代表 "\" 本身 |
\^ | 匹配 ^ 符号本身 |
\$ | 匹配 $ 符号本身 |
元字符 | 说明 |
. | 匹配除了换行符以外的任意字符 |
\w | 匹配字母、数字、下划线、汉字 |
\s | 匹配任意的空白符 |
\b | 单词的开始或结尾 |
\~ | 匹配字符串的开始 |
$ | 匹配字符串的结束 |
如:
\ba\w*\b :匹配以字母a开头的单词——先是某个单词开始处(\b),然后是字母a,然后是任意数量的字母或数字(\w*),最后是单词结束处(\b)。
\d+ :匹配1个或更多连续的数字。这里的+是和*类似的元字符,不同的是*匹配重复任意次(可能是0次),而+则匹配重复1次或更多次。
\b\w{6}\b: 匹配刚好6个字符的单词。
表达式 | 说明 |
[ ] | 包含一系列字符 |
[^ ] | 包含之外一系列字符 |
[ab5@]: 匹配 "a" 或 "b" 或 "5" 或 "@"
[^abc]: 包含abc之外的任意字符
[f-k]: f-k之间的任意字符
表达式 | 说明 |
{n} | 表达式重复n次,比如:"\w{2}" 相当于 "\w\w";"a{5}" 相当于 "aaaaa" |
{m,n} | 表达式至少重复m次,最多重复n次,比如:"ba{1,3}"可以匹配 "ba"或"baa"或"baaa |
{m,} | 表达式至少重复m次,比如:"\w\d{2,}"可以匹配 "a12","_456","M12344"... |
? | 匹配表达式0次或者1次,相当于 {0,1},比如:"a[cd]?"可以匹配 "a","ac","ad" |
+ | 表达式至少出现1次,相当于 {1,},比如:"a+b"可以匹配 "ab","aab","aaab"... |
* | 表达式不出现或出现任意次,相当于 {0,},比如:"\^*b"可以匹配 "b","^^^b"... |
1.简单的转义字符
一些不便书写的字符,采用在前面加 "/" 的方法。这些字符其实我们都已经熟知了。
表达式 | 可匹配 |
/r, /n | 代表回车和换行符 |
/t | 制表符 |
// | 代表 "/" 本身 |
表达式 | 可匹配 |
/^ | 匹配 ^ 符号本身 |
/$ | 匹配 $ 符号本身 |
/. | 匹配小数点(.)本身 |
正则表达式中的一些表示方法,可以匹配 '多种字符' 其中的任意一个字符。比如,表达式 "/d" 可以匹配任意一个数字。虽然可以匹配其中任意字符,但是只能是一个,不是多个。这就好比玩扑克牌时候,大小王可以代替任意一张牌,但是只能代替一张牌。
表达式 | 可匹配 |
/d | 任意一个数字,0~9 中的任意一个 |
/w | 任意一个字母或数字或下划线,也就是 A~Z,a~z,0~9,_ 中任意一个 |
/s | 包括空格、制表符、换页符等空白字符的其中任意一个 |
. | 小数点可以匹配除了换行符(/n)以外的任意一个字符 |
举例2:表达式 "a./d",在匹配 "aaa100" 时 ,匹配的结果是:成功;匹配到的内容是:"aa1";匹配到的位置是:开始于1,结束于4。