QT輸入框輸入限制整理(正則表達式限制)
在使用 輸入數(shù)值時,經(jīng)常遇到限制其范圍的需要,比如角太陽高度角范圍為[-90,90],經(jīng)度值范圍[-180,180],方位角范圍[0,360]。Qt提供了QIntValidator和QDoubleValidator可以限定數(shù)值輸入范圍,如使用QIntValidator限制整數(shù)的數(shù)值范圍:
1.只允許輸入字母和漢字:
QRegExp regExp; regExp.setPattern("[a-zA-Z0-9_\u4e00-\u9fa5\\w]+$"); QValidator * editName = new QRegExpValidator(regExp,ui->lineEdit); ui->lineEdit->setValidator(editName); ui->lineEdit->setMaxLength(10);
2.正則表達式限制 只允許輸入 浮點數(shù)
QRegExp rx("^(-?[0]|-?[1-9][0-9]{0,5})(?:\\.\\d{1,4})?$|(^\\t?$)");
3.使用正則表達式限制只能輸入數(shù)字
QRegExp rx("[0-9\.]+$"); QRegExpValidator *validator = new QRegExpValidator(rx, this); ui->lineEdit->setValidator(validator);
4.使用正則表達式限制只能輸入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");
5. 限制 輸入 值范圍,此類直接限制不接收數(shù)字以外的輸入,setRange設(shè)置接收范圍
QDoubleValidator * pDouVld = new QDoubleValidator(this); pDouVld->setRange(0,1000000000000000000); ui->lePort->setValidator(pDouVld);
6.只要字符數(shù)字
QRegExpValidator *validator2 = new QRegExpValidator(QRegExp("[A-Za-z0-9]*"), this); ui->leId->setValidator(validator2);
7.整理常用 正則表達式
^(-?[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. 式子中開頭的^和結(jié)尾的$限定字符串的開始和結(jié)尾; 2. "-?" 表示一個或0個負號,這里面的問號表示其前面的字符重復(fù)0次或1次; 3. 管道符“|”表示平行分組,比如后三個,表示180或其它形式; 4. [1-9] 表示限定數(shù)字范圍為1到9,其余類似,如果是有限幾個值,還可以用枚舉的方式,比如限定-255到255時,第一個數(shù)字2的限定,應(yīng)該表達為[1,2],這表示這個位置只允許是1或者2; 5. "\d"是一個轉(zhuǎn)義字符,表示匹配一位數(shù)字; 6. “\.” 表示匹配小數(shù)點; 7. "\d+",這里面的+表示其前面的\d重復(fù)一次或多次; 8. "\d{1,4}",里面的{1,4}表示重復(fù)1到4次;
8. 正則表達式語法:
:匹配任何單個字符。例如正則表達式“b.g”能匹配如下字符串:“big”、“bug”、“b g”,但是不匹配“buug”,“b..g”可以匹配“buug”。 [ ] :匹配括號中的任何一個字符。例如正則表達式“b[aui]g”匹配bug、big和bag,但是不匹配beg、baug。可以在括號中使用連字符“-”來指定字符的區(qū)間來簡化表示,例如正則表達式[0-9]可以匹配任何數(shù)字字符,這樣正則表達式“a[0-9]c”等價于“a[0123456789]c”就可以匹配“a0c”、“a1c”、“a2c”等字符串;還可以制定多個區(qū)間,例如“[A-Za-z]”可以匹配任何大小寫字母,“[A-Za-z0-9]”可以匹配任何的大小寫字母或者數(shù)字。 ( ) :將 () 之間括起來的表達式定義為“組”(group),并且將匹配這個表達式的字符保存到一個臨時區(qū)域,這個元字符在字符串提取的時候非常有用。把一些字符表示為一個整體。改變優(yōu)先級、定義提取組兩個作用。 | :將兩個匹配條件進行邏輯“或”運算。'z|food' 能匹配"z" 或 "food"。'(z|f)ood' 則匹配"zood" 或 "food"。 *:匹配0至多個在它之前的子表達式,和通配符*沒關(guān)系。例如正則表達式“zo*”能匹配 “z” 、“zo”以及 “zoo”;因此“.*”意味著能夠匹配任意字符串。"z(b|c)*"→zb、zbc、zcb、zccc、zbbbccc。"z(ab)*"能匹配z、zab、zabab(用括號改變優(yōu)先級)。 + :匹配前面的子表達式一次或多次,和*對比(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 次?!癳{1,3}”將匹配“seeeeeeeed”中的前三個“e”。 ^(shift+6) :匹配一行的開始。例如正則表達式“^regex”能夠匹配字符串“regex我會用”的開始,但是不能匹配“我會用regex”。 ^另外一種意思:非?。〞簳r不用理解) $ :匹配行結(jié)束符。例如正則表達式“浮云$” 能夠匹配字符串“一切都是浮云”的末尾,但是不能匹配字符串“浮云呀” \d:代表一個數(shù)字,等同于[0-9] \D:代表非數(shù)字,等同于[^0-9] \s:代表換行符、Tab制表符等空白字符 \S:代表非空白字符 \w:匹配字母或數(shù)字或下劃線或漢字,即能組成單詞的字符 \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+$"表示被匹配的字符序列應(yīng)該是由三至四位數(shù)字組成,由于長途區(qū)號的連字符“-”可有可無,所以這里使用“?”元字符進行說明。由于連字符“-”在正則表達式中有特殊含義(表示范圍,比如[0-9]),所以要對其進行轉(zhuǎn)義。 []括號中的任意字符,\w字母、數(shù)字、下劃線,+一到多個。由于.在正則表達式中有特殊的含義,因此對于真正想表達“.”則需要轉(zhuǎn)移“\.”。先想正則表達式是語言無關(guān)的。 +、*的匹配默認是貪婪(greedy)的:盡可能多的匹配,直到“再貪婪一點兒”其后的匹配模式就沒法匹配為止。 在+、*后添加?就變成非貪婪模式(? 的另外一個用途):讓其后的匹配模式盡早的匹配。修改成"我是(.+?)。" 圖片src[^>]*[^/].(?:jpg|bmp|gif)(?:\"|\') 中文 ^([\u4e00-\u9fa5]+|[a-zA-Z0-9]+)$ 網(wǎng)址"\<a.+?href=['""](?!http\:\/\/)(?!mailto\:)(?>foundAnchor>[^'"">]+?)[^>]*?\>" 匹配中文字符的正則表達式:[\u4e00-\u9fa5] 匹配雙字節(jié)字符(包括漢字在內(nèi)):[^\x00-\xff] 匹配空行的正則表達式:\n[\s|]*\r 匹配HTML標記的正則表達式:/<(.*)>.*<\/\1>|<(.*) \/>/ 匹配首尾空格的正則表達式:(^\s*)|(\s*$)(像vbscript那樣的trim函數(shù)) 匹配Email地址的正則表達式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)* 匹配網(wǎng)址URL的正則表達式:http://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?
總結(jié)
到此這篇關(guān)于QT輸入框輸入限制整理的文章就介紹到這了,更多相關(guān)QT輸入框輸入限制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言嵌入式實現(xiàn)支持浮點輸出的printf示例詳解
這篇文章主要為大家介紹了C語言嵌入式實現(xiàn)支持浮點輸出的printf示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01C++數(shù)據(jù)結(jié)構(gòu)二叉搜索樹的實現(xiàn)應(yīng)用與分析
從這篇博客開始,我就要和大家介紹有關(guān)二叉搜索樹的知識,它還衍生出了兩棵樹——AVL樹和紅黑樹,在后面兩篇博客我都會介紹。今天先從二叉搜索樹開始引入2022-02-02c++之移動構(gòu)造函數(shù)或者移動賦值運算符的作用詳解
文章介紹了移動構(gòu)造函數(shù)和移動賦值運算符的核心作用,它們通過資源管理權(quán)轉(zhuǎn)移的方式實現(xiàn)對象的構(gòu)造,減少內(nèi)存拷貝的開銷,移動構(gòu)造函數(shù)的參數(shù)一定是一個右值引用2025-03-03c++中數(shù)字與字符串之間的轉(zhuǎn)換方法(推薦)
下面小編就為大家?guī)硪黄猚++中數(shù)字與字符串之間的轉(zhuǎn)換方法(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09深入剖析設(shè)計模式中的組合模式應(yīng)用及在C++中的實現(xiàn)
這篇文章主要介紹了設(shè)計模式中的組合模式應(yīng)用及在C++中的實現(xiàn),組合模式可以清晰地反映出遞歸構(gòu)建樹狀的組合結(jié)構(gòu),需要的朋友可以參考下2016-03-03