正则表达式
例如:判断手机号时,我们需要根据一下三个方面进行代码设计。 1.手机号必须以1开头 2.手机号第二位必须为3、5、7、8 3.手机号为11位的纯数字 static void Main(string[] args) { bool result = CheckPhoneNumber("13788990087"); Console.WriteLine(result); Console.ReadLine(); } public static bool CheckPhoneNumber(string number) { bool oneNum = !(number[0] == 1); bool twoNum = !(number[1] == 3 || number[1] == 5 || number[1] == 7 || number[1] == 8); bool phoneNum = true; for (int i = 0; i < number.Length; i++) { if (number[i] <= ‘0‘ && number[i] >= ‘9‘) { phoneNum = false; break; } } bool length = number.Length == 11; return oneNum && twoNum && phoneNum && length; } ? ?正则表达式:用来判断某一个字符串是否匹配一定的格式(就是定义一种规则去匹配符合规则的字符)。 ^ :用来匹配行或者字符串的起始位置,有时还会匹配整个文档的起始位置。? $ :用来匹配行或字符串的结尾 [ ]:只能匹配一位字符,这位字符可以实这个中括号中任意一个 [1-9]:表示1到9连续的数字 [a-z]:表示小写字母 [A-Z]:表示大写字母 [a-zA-Z]或[A-Za-z]:表示所有字母 [a-zA-Z0-9]:所有字母或数字 [^1-9]:表示除了1到9剩下都可以 ? (‘^’在此表示取反) //实例化一个正则表达式的对象 Regex r = new Regex("^[abchei]ello,world!$"); bool result= r.IsMatch("hello,world!"); Console.WriteLine(result); 结果:Ture +:表示前面的一位字符连续出现了一次或多次 *:表示前面的一位字符可以出现可以不出现 ?:表示前面的一位字符连续出现了0次或1次 Regex r = new Regex("^hel+o$"); bool result= r.IsMatch("hello"); Console.WriteLine(result); 结果:True ? Regex r = new Regex("^hel*o$"); bool result= r.IsMatch("hellllllllo"); Console.WriteLine(result); 结果:True ? Regex r = new Regex("^hel?o$"); bool result= r.IsMatch("hellllllo"); Console.WriteLine(result); 结果:False {m}:表示前面的一位字符连续出现了m次 {m,}:表示前面的一位字符至少连续出现了m次 {m,n}:表示前面的一位字符出现了m到n次(大于m小于n次) ? Regex r = new Regex("^hel{3}o$"); :匹配""否则转义。 .:通配符(匹配除了换行符以外的任何字符) d:表示[0-9],匹配数字。 D:表示匹配除[0-9]以外的符号。 b :用于匹配单词边界,不会消耗任何字符只匹配一个位置,例如:我想从字符串中"This is Regex"匹配单独的单词 "is" 正则就要写成 "bisb"。b 不会匹配is 两边的字符,但它会识别is 两边是否为单词的边界。 w:匹配字母,数字,下划线。 s:匹配空格。例如字符 "a b c" 正则:"wswsw"一个字符后跟一个空格,如有字符间有多个空格直接把"s" 写成 "s+" 让空格重复 *? :重复任意次,但尽可能少重复。如 "acbacb"正则"a.*?b"只会取到第一个"acb" 原本可以全部取到但加了限定符后,只会匹配尽可能少的字符 ,而"acbacb"最少字符的结果就是"acb" +?:重复1次或更多次。 ??:重复0次或1次,但尽可能少重复。如 "aaacb" 正则 "a.??b" 只会取到最后的三个字符"acb" {n,m}?:重复n到m次,但尽可能少重复。如 "aaaaaaaa" ?正则 "a{0,m}" 因为最少是0次所以取到结果为空 {n,}?:重复n次以上,但尽可能少重复。如 "aaaaaaa" ?正则 "a{1,}" 最少是1次所以取到结果为 "a" ? 我们再回看上面判断是否为手机号的例子,就可以用正则表达式很简单的写出来: ^1[3578]d{9}$ ? 例:判断是否正确身份证号: 1.第一位不为0 2.15位或18位 3.最后一位可以为X 4.十八位:xxxxxx YYYY mm dd xxx x ?? 十五位:xxxxxx? YY mm dd xx x 地区: [1-9]d{5} 年的前两位: (18|19|([20]d)) 1800-2099 年的后两位: d{2} 月份: ((0[1-9])|(10|11|12)) 天数: (([0-2][1-9])|10|20|30|31) 闰年不能禁止29+ 三位顺序码: d{3} 两位顺序码: d{2} 校验码: [0-9Xx] 正则表达式 十八位: ^[1-9]d{5}(18|19|([20]d))d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)d{3}[0-9Xx]$ 十五位: ^[1-9]d{5}d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)d{2}$ 总: ( ^[1-9]d{5}(18|19|([20]d))d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |