例如:判断手机号时,我们需要根据一下三个方面进行代码设计。
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$");
bool result= r.IsMatch("helllo");
Console.WriteLine(result); 结果:True Regex r = new Regex("^hel{3,}o$");
bool result= r.IsMatch("helllllllo");
Console.WriteLine(result); 结果:True Regex r = new Regex("^hel{3,6}o$");
bool result= r.IsMatch("helllllllo");
Console.WriteLine(result); 结果:False
\\:匹配"\"否则转义。
.:通配符(匹配除了换行符以外的任何字符)
\d:表示[0-9],匹配数字。
\D:表示匹配除[0-9]以外的符号。
\b :用于匹配单词边界,不会消耗任何字符只匹配一个位置,例如:我想从字符串中"This is Regex"匹配单独的单词 "is" 正则就要写成 "\bis\b"。\b 不会匹配is 两边的字符,但它会识别is 两边是否为单词的边界。
\w:匹配字母,数字,下划线。
\s:匹配空格。例如字符 "a b c" 正则:"\w\s\w\s\w"一个字符后跟一个空格,如有字符间有多个空格直接把"\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)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。