.net中常用的正則表達(dá)式
更新時(shí)間:2022年04月23日 15:28:17 作者:農(nóng)碼一生
這篇文章介紹了.net中常用的正則表達(dá)式,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
一、匹配字符串
正則1
//正則1
Regex r = new Regex("abc"); // 定義一個(gè)Regex對象實(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í)際開發(fā)中請勿使用中文命名變量
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}$");
//零和非零開頭的數(shù)字
Regex reg = new Regex(@"^(0|[1-9][0-9]*)$");
//非零開頭的最多帶兩位小數(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}$");
//長度為3-20的所有字符
Regex reg = new Regex(@"^.{3,20}$");
//由26個(gè)英文字母組成的字符串
Regex reg = new Regex(@"^[A-Za-z]+$");
//由26個(gè)大寫英文字母組成的字符串
Regex reg = new Regex(@"^[A-Z]+$");
//由26個(gè)小寫英文字母組成的字符串
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ù)字但不包括下劃線等符號
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ī)號碼
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}$");
//電話號碼(“XXX-XXXXXXX”、”XXXX-XXXXXXXX”、”XXX-XXXXXXX”、”XXX-XXXXXXXX”、”XXXXXXX”和”XXXXXXXX)
Regex reg = new Regex(@"^($$\d{3,4}-)|\d{3.4}-)?\d{7,8}$");
//國內(nèi)電話號碼(0511-4405222、021-87888822)
Regex reg = new Regex(@"\d{3}-\d{8}|\d{4}-\d{7}");
//身份證號(15位、18位數(shù)字)
Regex reg = new Regex(@"^\d{15}|\d{18}$");
//短身份證號碼(數(shù)字、字母x結(jié)尾)
Regex reg = new Regex(@"^([0-9]){7,18}(x|X)?$ 或 ^\d{8,18}|[0-9x]{8,18}|[0-9X]{8,18}?$");
//帳號是否合法(字母開頭,允許5-16字節(jié),允許字母數(shù)字下劃線)
Regex reg = new Regex(@"^[a-zA-Z][a-zA-Z0-9_]{4,15}$");
//密碼(以字母開頭,長度在6~18之間,只能包含字母、數(shù)字和下劃線)
Regex reg = new Regex(@"^[a-zA-Z]\w{5,17}$");
//強(qiáng)密碼(必須包含大小寫字母和數(shù)字的組合,不能使用特殊字符,長度在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”, 和沒有 “分” 的 “10000” 和 “10,000”
Regex reg = new Regex(@"^[1-9][0-9]*$");
//這表示任意一個(gè)不以0開頭的數(shù)字,但是,這也意味著一個(gè)字符”0″不通過,所以我們采用下面的形式
Regex reg = new Regex(@"^(0|[1-9][0-9]*)$");
//一個(gè)0或者一個(gè)不以0開頭的數(shù)字.我們還可以允許開頭有一個(gè)負(fù)號
Regex reg = new Regex(@"^(0|-?[1-9][0-9]*)$");
//這表示一個(gè)0或者一個(gè)可能為負(fù)的開頭不為0的數(shù)字.讓用戶以0開頭好了.把負(fù)號的也去掉,因?yàn)殄X總不能是負(fù)的吧.下面我們要加的是說明可能的小數(shù)部分
Regex reg = new Regex(@"^[0-9]+(.[0-9]+)?$");
//必須說明的是,小數(shù)點(diǎn)后面至少應(yīng)該有1位數(shù),所以”10.”是不通過的,但是 “10” 和 “10.2” 是通過的
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})?$");
//這樣就允許用戶只寫一位小數(shù)。下面我們該考慮數(shù)字中的逗號了,我們可以這樣
Regex reg = new Regex(@"^[0-9]{1,3}(,[0-9]{3})*(.[0-9]{1,2})?$");
//1到3個(gè)數(shù)字,后面跟著任意個(gè) 逗號+3個(gè)數(shù)字,逗號成為可選,而不是必須
Regex reg = new Regex(@"^([0-9]+|[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$");
//備注:這就是最終結(jié)果了,別忘了”+”可以用”*”替代。如果你覺得空字符串也可以接受的話(奇怪,為什么?)最后,別忘了在用函數(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),可以用來計(jì)算字符串的長度(一個(gè)雙字節(jié)字符長度計(jì)2,ASCII字符計(jì)1))");
//空白行的正則表達(dá)式,可用來刪除空白行
Regex reg = new Regex(@"\n\s*\r");
//HTML標(biāo)記的正則表達(dá)式
Regex reg = new Regex(@"<(\S*?)[^>]*>.*?</\1>|<.*? />");// (網(wǎng)上流傳的版本太糟糕,上面這個(gè)也僅僅能部分,對于復(fù)雜的嵌套標(biāo)記依舊無能為力)
//首尾空白字符的正則表達(dá)式
Regex reg = new Regex(@"^\s*|\s*$或(^\s*)|(\s*$)");// (可以用來刪除行首行尾的空白字符(包括空格、制表符、換頁符等等),非常有用的表達(dá)式)
//騰訊QQ號
Regex reg = new Regex(@"[1-9][0-9]{4,}"); //(騰訊QQ號從10000開始)
//中國郵政編碼
Regex reg = new Regex(@"[1-9]\d{5}(?!\d)");// (中國郵政編碼為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á)式的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
c#實(shí)現(xiàn)識別圖片上的驗(yàn)證碼數(shù)字
這篇文章主要介紹了c#實(shí)現(xiàn)識別圖片上的驗(yàn)證碼數(shù)字的方法,本文給大家匯總了2種方法,有需要的小伙伴可以參考下。2015-11-11
C#判斷當(dāng)前程序是否通過管理員運(yùn)行的方法
這篇文章主要介紹了C#判斷當(dāng)前程序是否通過管理員運(yùn)行的方法,可通過非常簡單的系統(tǒng)函數(shù)調(diào)用實(shí)現(xiàn)對當(dāng)前程序是否通過管理員運(yùn)行進(jìn)行判定,是非常實(shí)用的技巧,需要的朋友可以參考下2014-11-11
C#獲取ListView鼠標(biāo)下的Item實(shí)例
下面小編就為大家?guī)硪黄狢#獲取ListView鼠標(biāo)下的Item實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-01-01
C#連接SQL數(shù)據(jù)庫和查詢數(shù)據(jù)功能的操作技巧
本文給大家分享C#連接SQL數(shù)據(jù)庫和查詢數(shù)據(jù)功能的操作技巧,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-05-05

