Qt⼯作笔记-QLineEdit⽤正则限制⽂本框的输⼊内容+正则表
达式语法
原⽂地址:
blog.csdn/graceland525/article/details/48676071
//使⽤正则表达式限制只能输⼊数字
QRegExp rx("[0-9\.]+$");
QRegExpValidator *validator = new QRegExpValidator(rx, this);
ui->lineEdit->setValidator(validator);
//使⽤正则表达式限制只能输⼊IP地址
QRegExp rx = QRegExp("((2[0-4]\\d|25[0-5]|[01]?\\d\\d?)\\.){4}");
QRegExpValidator *validator = new QRegExpValidator(rx, this);
ui->lineEdit->setValidator(validator);
ui->lineEdit->setInputMask("000.000.000.000");
简单说明⼀下这⼏个正则表达式:
^(-?[0]|-?[1-9][0-9]{0,5})(?:\.\d{1,4})?$|(^\t?$)
(^-?180$)|(^-?1[0-7]\d$)|(^-?[1-9]\d$)|(^-?[1-9]$)|^0$
^-?(180|1?[0-7]?\d(\.\d+)?)$
^-?(180|1?[0-7]?\d(\.\d{1,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"是⼀个转义字符,表⽰匹配⼀位数字;
6.  “\.” 表⽰匹配⼩数点;
7.  "\d+",这⾥⾯的+表⽰其前⾯的\d重复⼀次或多次;
8.  "\d{1,4}",⾥⾯的{1,4}表⽰重复1到4次;
正则表达式语法:
. :匹配任何单个字符。例如正则表达式“b.g”能匹配如下字符串:“big”、“bug”、“b g”,但是不匹配“buug”,“b..g”可以匹配“buug”。
[ ] :匹配括号中的任何⼀个字符。例如正则表达式“b[aui]g”匹配bug、big和bag,但是不匹配beg、baug。可以在括号中使⽤连字
符“-”来指定字符的区间来简化表⽰,例如正则表达式[0-9]可以匹配任何数字字符,这样正则表达式“a[0-9]c”等价
于“a[0123456789]c”就可以匹配“a0c”、“a1c”、“a2c”等字符串;还可以制定多个区间,例如“[A-Za-z]”可以匹配任何⼤⼩写字母,“[A-Za-z0-9]”可以匹配任何的⼤⼩写字母或者数字。
( ) :将 () 之间括起来的表达式定义为“组”(group),并且将匹配这个表达式的字符保存到⼀个临时区域,这个元字符在字符串提取的时候⾮常有⽤。把⼀些字符表⽰为⼀个整体。改变优先级、定义提取组两个作⽤。
| :将两个匹配条件进⾏逻辑“或”运算。'z|food' 能匹配"z" 或 "food"。'(z|f)ood' 则匹配"zood" 或 "food"。
*:匹配0⾄多个在它之前的⼦表达式,和通配符*没关系。例如正则表达式“zo*”能匹配 “z” 、“zo”以及 “zoo”;因此“.*”意味着能够匹配任意字符串。"z(b|c)*"→zb、zbc、zcb、zccc、zbbbccc。"z(ab)*"能匹配z、zab、zabab(⽤括号改变优先级)。
+ :匹配前⾯的⼦表达式⼀次或多次,和*对⽐(0到多次)。例如正则表达式9+匹配9、99、999等。 “zo+”能匹配 “zo”以及“zoo” ,不能匹配"z"。
匹配前⾯的⼦表达式零次或⼀次。例如,"do(es)" 可以匹配 "do" 或"does" 。⼀般⽤来匹配“可选部分”。
{n} :匹配确定的 n 次。"zo{2}"→zoo。例如,“e{2}” 不能匹配“bed”中的“e”,但是能匹配“seed”中的两个“e”。
正则表达式提取中文字符{n,} :⾄少匹配n次。例如,“e{2,}”不能匹配“bed”中的“e”,但能匹配 “seeeeeeeed”中的所有“e”。
{n,m} :最少匹配 n 次且最多匹配 m 次。“e{1,3}”将匹配“seeeeeeeed”中的前三个“e”。
^(shift+6) :匹配⼀⾏的开始。例如正则表达式“^regex”能够匹配字符串“regex我会⽤”的开始,但是不能匹配“我会⽤regex”。
^另外⼀种意思:⾮!(暂时不⽤理解)
$ :匹配⾏结束符。例如正则表达式“浮云$” 能够匹配字符串“⼀切都是浮云”的末尾,但是不能匹配字符串“浮云呀”
\d:代表⼀个数字,等同于[0-9]
\D:代表⾮数字,等同于[^0-9]
\s:代表换⾏符、Tab制表符等空⽩字符
\S:代表⾮空⽩字符
\w:匹配字母或数字或下划线或汉字,即能组成单词的字符
\W:⾮\w ,等同于[^\w]
d:digital;s:space、w:word。⼤写就是“⾮”
Regex.IsMatch("bbbbg","^b.*g$");
Regex.IsMatch("bg","^b.*g $ ");
Regex.IsMatch("gege","^b.*g $ ");
"^\d{3,4}\-?\d+$"表⽰被匹配的字符序列应该是由三⾄四位数字组成,由于长途区号的连字符“-”可有可⽆,所以这⾥使⽤“?”元字符进⾏说明。由于连字符“-”在正则表达式中有特殊含义(表⽰范围,⽐如[0-9]),所以要对其进⾏转义。
[]括号中的任意字符,\w字母、数字、下划线,+⼀到多个。由于.在正则表达式中有特殊的含义,因此
对于真正想表达“.”则需要转
移“\.”。先想正则表达式是语⾔⽆关的。
+、*的匹配默认是贪婪(greedy)的:尽可能多的匹配,直到“再贪婪⼀点⼉”其后的匹配模式就没法匹配为⽌。
在+、*后添加?就变成⾮贪婪模式(? 的另外⼀个⽤途):让其后的匹配模式尽早的匹配。修改成"我是(.+?)。"
图⽚src[^>]*[^/].(?:jpg|bmp|gif)(?:\"|\')
中⽂ ^([\u4e00-\u9fa5]+|[a-zA-Z0-9]+)$
⽹址"\<a.+?href=['""](?!http\:\/\/)(?!mailto\:)(?>foundAnchor>[^'"">]+?)[^>]*?\>"
匹配中⽂字符的正则表达式:[\u4e00-\u9fa5]
匹配双字节字符(包括汉字在内):[^\x00-\xff]
匹配空⾏的正则表达式:\n[\s|]*\r
匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*) \/>/
匹配⾸尾空格的正则表达式:(^\s*)|(\s*$)(像vbscript那样的trim函数)
匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。