限制QLineEdit的数值输入范围(QT正则表达式方法),顺便简单介绍下QT正则表达式方法

首先看几个例子:


1.限制浮点数输入范围为[-180,180]
    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

制表符

//

代表 "/" 本身

    还有其他一些在后边章节中有特殊用处的标点符号,在前面加 "/" 后,就代表该符号本身。比如:^, $ 都有特殊意义,如果要想匹配字符串中 "^" 和 "$" 字符,则表达式就需要写成 "/^" 和 "/$"。

表达式

可匹配

/^

匹配 ^ 符号本身

/$

匹配 $ 符号本身

/.

匹配小数点(.)本身

2. 能够与 '多种字符' 匹配的表达式

    正则表达式中的一些表示方法,可以匹配 '多种字符' 其中的任意一个字符。比如,表达式 "/d" 可以匹配任意一个数字。虽然可以匹配其中任意字符,但是只能是一个,不是多个。这就好比玩扑克牌时候,大小王可以代替任意一张牌,但是只能代替一张牌。

表达式

可匹配

/d

任意一个数字,0~9 中的任意一个

/w

任意一个字母或数字或下划线,也就是 A~Z,a~z,0~9,_ 中任意一个

/s

包括空格、制表符、换页符等空白字符的其中任意一个

.

小数点可以匹配除了换行符(/n)以外的任意一个字符

     举例1:表达式 "/d/d",在匹配 "abc123" 时 ,匹配的结果是:成功;匹配到的内容是:"12";匹配到的位置是:开始于3,结束于5。

      举例2:表达式 "a./d",在匹配 "aaa100" 时 ,匹配的结果是:成功;匹配到的内容是:"aa1";匹配到的位置是:开始于1,结束于4。

猜你喜欢

转载自blog.csdn.net/seekn/article/details/72448786