欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

.net中常用的正則表達(dá)式

 更新時(shí)間:2022年04月23日 15:28:17   作者:農(nóng)碼一生  
這篇文章介紹了.net中常用的正則表達(dá)式,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

一、匹配字符串

正則1

            //正則1
            Regex r = new Regex("abc"); // 定義一個(gè)Regex對(duì)象實(shí)例
            Match m = r.Match("123abc456"); // 在字符串中匹配
            if (m.Success)
            {
                //匹配
            }

            //正則2
            r = new Regex("(abc)*");
            m = r.Match("bcabcabc");
            if (m.Success)
            {
                //匹配
            }

正則2

            //字符串匹配
            string line = "ADDR=1234;NAME=ZHANG;PHONE=6789";
            Regex reg = new Regex("NAME=(.+);");
            //例如我想提取line中的NAME值
            Match match = reg.Match(line);
            string value = match.Groups[1].Value;
            Console.WriteLine("value的值為:{0}", value);

二、字符串替換

            //字符串替換
            //例如我想把如下格式記錄中的NAME值修改為WANG
            string line = "ADDR=1234;NAME=ZHANG;PHONE=6789";
            Regex reg = new Regex("NAME=(.+);");
            string modified = reg.Replace(line, "NAME=WANG;");
            //修改后的字符串為 ADDR=1234;NAME=WANG;PHONE=6789

三、Match

            //Match
            //文本中含有"speed=30.3mph",需要提取該速度值,但是速度的單位可能是公制也可能是英制,mph,km/h,m/s都有可能;另外前后可能有空格。
            string line = "lane=1;speed=30.3mph;acceleration=2.5mph/s";
            Regex reg = new Regex(@"speed\s*=\s*([\d\.]+)\s*(mph|km/h|m/s)*");
            Match match = reg.Match(line);
            //那么在返回的結(jié)果中match.Groups[1].Value將含有數(shù)值,而match.Groups[2].Value將含有單位。
            var 值 = match.Groups[1].Value;//此處方便演示,在實(shí)際開(kāi)發(fā)中請(qǐng)勿使用中文命名變量
            var 單位 = match.Groups[2].Value;
            Console.WriteLine("speed的值為:{0} speed的單位是:{1}", 值, 單位);

四、提取[]的值

string pattern1 = @"(?is)(?<=\[)(.*)(?=\])";
string result1 = new Regex(pattern1).Match("sadff[xxx]sdfdsf").Value;

五、提取()的值

string pattern2 = @"(?is)(?<=\()(.*)(?=\))";
string result2 = new Regex(pattern2).Match("sad(f)dsf").Value;

string pattern3 = @"(?is)(?<=\{)(.*)(?=\})";
string result3 = new Regex(pattern3).Match("sadff[{xxx]sdfd}sf").Value;

六、驗(yàn)證數(shù)字表達(dá)式

            //數(shù)字
            Regex reg = new Regex(@"^[0-9]*$");
            //n位的數(shù)字
            Regex reg = new Regex(@"^\d{n}$");
            //至少n位的數(shù)字
            Regex reg = new Regex(@"^\d{n,}$");
            //m-n位的數(shù)字
            Regex reg = new Regex(@"^\d{m,n}$");
            //零和非零開(kāi)頭的數(shù)字
            Regex reg = new Regex(@"^(0|[1-9][0-9]*)$");
            //非零開(kāi)頭的最多帶兩位小數(shù)的數(shù)字
            Regex reg = new Regex(@"^([1-9][0-9]*)+(.[0-9]{1,2})?$");
            //帶1-2位小數(shù)的正數(shù)或負(fù)數(shù)
            Regex reg = new Regex(@"^(\-)?\d+(\.\d{1,2})?$");
            //正數(shù)、負(fù)數(shù)、和小數(shù)
            Regex reg = new Regex(@"^(\-|\+)?\d+(\.\d+)?$");
            //有兩位小數(shù)的正實(shí)數(shù)
            Regex reg = new Regex(@"^[0-9]+(.[0-9]{2})?$");
            //有1~3位小數(shù)的正實(shí)數(shù)
            Regex reg = new Regex(@"^[0-9]+(.[0-9]{1,3})?$");
            //非零的正整數(shù)
            Regex reg = new Regex(@"^[1-9]\d*$ 或 ^([1-9][0-9]*){1,3}$ 或 ^\+?[1-9][0-9]*$");
            //非零的負(fù)整數(shù)
            Regex reg = new Regex(@"^\-[1-9][]0-9″*$ 或 ^-[1-9]\d*$");
            //非負(fù)整數(shù)
            Regex reg = new Regex(@"^\d+$ 或 ^[1-9]\d*|0$");
            //非正整數(shù)
            Regex reg = new Regex(@"^-[1-9]\d*|0$ 或 ^((-\d+)|(0+))$");
            //非負(fù)浮點(diǎn)數(shù)
            Regex reg = new Regex(@"^\d+(\.\d+)?$ 或 ^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$");
            //非正浮點(diǎn)數(shù)
            Regex reg = new Regex(@"^((-\d+(\.\d+)?)|(0+(\.0+)?))$ 或 ^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$");
            //正浮點(diǎn)數(shù)
            Regex reg = new Regex(@"^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ 或 ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$");
            //負(fù)浮點(diǎn)數(shù)
            Regex reg = new Regex(@"^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$ 或 ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$");
            //浮點(diǎn)數(shù)
            Regex reg = new Regex(@"^(-?\d+)(\.\d+)?$ 或 ^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$");

七、驗(yàn)證字符表達(dá)式

            //漢字
            Regex reg = new Regex(@"^[\u4e00-\u9fa5]{0,}$");
            //英文和數(shù)字
            Regex reg = new Regex(@"^[A-Za-z0-9]+$ 或 ^[A-Za-z0-9]{4,40}$");
            //長(zhǎng)度為3-20的所有字符
            Regex reg = new Regex(@"^.{3,20}$");
            //由26個(gè)英文字母組成的字符串
            Regex reg = new Regex(@"^[A-Za-z]+$");
            //由26個(gè)大寫(xiě)英文字母組成的字符串
            Regex reg = new Regex(@"^[A-Z]+$");
            //由26個(gè)小寫(xiě)英文字母組成的字符串
            Regex reg = new Regex(@"^[a-z]+$");
            //由數(shù)字和26個(gè)英文字母組成的字符串
            Regex reg = new Regex(@"^[A-Za-z0-9]+$");
            //由數(shù)字、26個(gè)英文字母或者下劃線組成的字符串
            Regex reg = new Regex(@"^\w+$ 或 ^\w{3,20}$");
            //中文、英文、數(shù)字包括下劃線
            Regex reg = new Regex(@"^[\u4E00-\u9FA5A-Za-z0-9_]+$");
            //中文、英文、數(shù)字但不包括下劃線等符號(hào)
            Regex reg = new Regex(@"^[\u4E00-\u9FA5A-Za-z0-9]+$ 或 ^[\u4E00-\u9FA5A-Za-z0-9]{2,20}$");
            //可以輸入含有^%&',;=?$\”等字符
            Regex reg = new Regex(@"[^%&',;=?$\x22]+");
            //禁止輸入含有~的字符
            Regex reg = new Regex(@"[^~\x22]+");

八、特殊需求表達(dá)式

            //Email地址
            Regex reg = new Regex(@"^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$");
            //域名
            Regex reg = new Regex(@"[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?");
            //InternetURL
            Regex reg = new Regex(@"[a-zA-z]+://[^\s]* 或 ^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$");
            //手機(jī)號(hào)碼
            Regex reg = new Regex(@"^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$");
            //電話號(hào)碼(“XXX-XXXXXXX”、”XXXX-XXXXXXXX”、”XXX-XXXXXXX”、”XXX-XXXXXXXX”、”XXXXXXX”和”XXXXXXXX)
            Regex reg = new Regex(@"^($$\d{3,4}-)|\d{3.4}-)?\d{7,8}$");
            //國(guó)內(nèi)電話號(hào)碼(0511-4405222、021-87888822)
            Regex reg = new Regex(@"\d{3}-\d{8}|\d{4}-\d{7}");
            //身份證號(hào)(15位、18位數(shù)字)
            Regex reg = new Regex(@"^\d{15}|\d{18}$");
            //短身份證號(hào)碼(數(shù)字、字母x結(jié)尾)
            Regex reg = new Regex(@"^([0-9]){7,18}(x|X)?$ 或 ^\d{8,18}|[0-9x]{8,18}|[0-9X]{8,18}?$");
            //帳號(hào)是否合法(字母開(kāi)頭,允許5-16字節(jié),允許字母數(shù)字下劃線)
            Regex reg = new Regex(@"^[a-zA-Z][a-zA-Z0-9_]{4,15}$");
            //密碼(以字母開(kāi)頭,長(zhǎng)度在6~18之間,只能包含字母、數(shù)字和下劃線)
            Regex reg = new Regex(@"^[a-zA-Z]\w{5,17}$");
            //強(qiáng)密碼(必須包含大小寫(xiě)字母和數(shù)字的組合,不能使用特殊字符,長(zhǎng)度在8-10之間)
            Regex reg = new Regex(@"^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$");
            //日期格式
            Regex reg = new Regex(@"^\d{4}-\d{1,2}-\d{1,2}");
            //一年的12個(gè)月(01~09和1~12)
            Regex reg = new Regex(@"^(0?[1-9]|1[0-2])$");
            //一個(gè)月的31天(01~09和1~31)
            Regex reg = new Regex(@"^((0?[1-9])|((1|2)[0-9])|30|31)$");
            //錢的輸入格式:
            //有四種錢的表示形式我們可以接受:”10000.00″ 和 “10,000.00”, 和沒(méi)有 “分” 的 “10000” 和 “10,000”
            Regex reg = new Regex(@"^[1-9][0-9]*$");
            //這表示任意一個(gè)不以0開(kāi)頭的數(shù)字,但是,這也意味著一個(gè)字符”0″不通過(guò),所以我們采用下面的形式
            Regex reg = new Regex(@"^(0|[1-9][0-9]*)$");
            //一個(gè)0或者一個(gè)不以0開(kāi)頭的數(shù)字.我們還可以允許開(kāi)頭有一個(gè)負(fù)號(hào)
            Regex reg = new Regex(@"^(0|-?[1-9][0-9]*)$");
            //這表示一個(gè)0或者一個(gè)可能為負(fù)的開(kāi)頭不為0的數(shù)字.讓用戶以0開(kāi)頭好了.把負(fù)號(hào)的也去掉,因?yàn)殄X總不能是負(fù)的吧.下面我們要加的是說(shuō)明可能的小數(shù)部分
            Regex reg = new Regex(@"^[0-9]+(.[0-9]+)?$");
            //必須說(shuō)明的是,小數(shù)點(diǎn)后面至少應(yīng)該有1位數(shù),所以”10.”是不通過(guò)的,但是 “10” 和 “10.2” 是通過(guò)的
            Regex reg = new Regex(@"^[0-9]+(.[0-9]{2})?$");
            //這樣我們規(guī)定小數(shù)點(diǎn)后面必須有兩位,如果你認(rèn)為太苛刻了,可以這樣
            Regex reg = new Regex(@"^[0-9]+(.[0-9]{1,2})?$");
            //這樣就允許用戶只寫(xiě)一位小數(shù)。下面我們?cè)摽紤]數(shù)字中的逗號(hào)了,我們可以這樣
            Regex reg = new Regex(@"^[0-9]{1,3}(,[0-9]{3})*(.[0-9]{1,2})?$");
            //1到3個(gè)數(shù)字,后面跟著任意個(gè) 逗號(hào)+3個(gè)數(shù)字,逗號(hào)成為可選,而不是必須
            Regex reg = new Regex(@"^([0-9]+|[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$");
            //備注:這就是最終結(jié)果了,別忘了”+”可以用”*”替代。如果你覺(jué)得空字符串也可以接受的話(奇怪,為什么?)最后,別忘了在用函數(shù)時(shí)去掉去掉那個(gè)反斜杠,一般的錯(cuò)誤都在這里
            //xml文件
            Regex reg = new Regex(@"^([a-zA-Z]+-?)+[a-zA-Z0-9]+\\.[x|X][m|M][l|L]$");
            //中文字符的正則表達(dá)式
            Regex reg = new Regex(@"[\u4e00-\u9fa5]");
            //雙字節(jié)字符
            Regex reg = new Regex(@"[^\x00-\xff] (包括漢字在內(nèi),可以用來(lái)計(jì)算字符串的長(zhǎng)度(一個(gè)雙字節(jié)字符長(zhǎng)度計(jì)2,ASCII字符計(jì)1))");
            //空白行的正則表達(dá)式,可用來(lái)刪除空白行
            Regex reg = new Regex(@"\n\s*\r");
            //HTML標(biāo)記的正則表達(dá)式
            Regex reg = new Regex(@"<(\S*?)[^>]*>.*?</\1>|<.*? />");// (網(wǎng)上流傳的版本太糟糕,上面這個(gè)也僅僅能部分,對(duì)于復(fù)雜的嵌套標(biāo)記依舊無(wú)能為力)
            //首尾空白字符的正則表達(dá)式
            Regex reg = new Regex(@"^\s*|\s*$或(^\s*)|(\s*$)");// (可以用來(lái)刪除行首行尾的空白字符(包括空格、制表符、換頁(yè)符等等),非常有用的表達(dá)式)
            //騰訊QQ號(hào)
            Regex reg = new Regex(@"[1-9][0-9]{4,}"); //(騰訊QQ號(hào)從10000開(kāi)始)
            //中國(guó)郵政編碼
            Regex reg = new Regex(@"[1-9]\d{5}(?!\d)");// (中國(guó)郵政編碼為6位數(shù)字)
            //IP地址
            Regex reg = new Regex(@"\d+\.\d+\.\d+\.\d+");// (提取IP地址時(shí)有用)
            //IP地址
            Regex reg = new Regex(@"((?:(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d))");

到此這篇關(guān)于.net正則表達(dá)式的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論