加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

正则表达式

发布时间:2020-12-14 06:16:28 所属栏目:百科 来源:网络整理
导读:例如:判断手机号时,我们需要根据一下三个方面进行代码设计。 1.手机号必须以1开头 2.手机号第二位必须为3、5、7、8 3.手机号为11位的纯数字 static void Main( string [] args){ bool result = CheckPhoneNumber( " 13788990087 " ); Console.WriteLine(re

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

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" 正则就要写成 "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)
判断身份证号

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读