微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

正则表达式

例如:判断手机号时,我们需要根据一下三个方面进行代码设计。

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)
判断身份证号

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐