您好,欢迎访问三七文档
当前位置:首页 > 办公文档 > 统计图表 > C#正则表达式整理备忘
正则表达式基础知识基本语法在正则表达式中拥有一套自己的语法规则,常见语法包括;字符匹配、重复匹配、字符定位、转义匹配和其他高级语法(字符分组、字符替换和字符决策);字符匹配语法:字符语法语法解释语法例子\d匹配数字(0~9)‘\d’匹配8,不匹配12;\D匹配非数字‘\D’匹配c,不匹配3;\w匹配任意单字符‘\w\w’匹配A3,不匹配@3;\W匹配非单字符‘\W’匹配@,不匹配c;\s匹配空白字符‘\d\s\d’匹配3d,不匹配abc;\S匹配非空字符‘\S\S\S’匹配A#4,不匹配3d;.匹配任意字符‘....’匹配A$5,不匹配换行;[…]匹配括号中任意字符[b-d]匹配b、c、d,不匹配e;[^…]匹配非括号字符[^b-z]匹配a,不匹配b-z的字符;重复匹配语法:重复语法语法解释语法例子{n}匹配n次字符\d{3}匹配\d\d\d,不匹配\d\d或\d\d\d\d{n,}匹配n次和n次以上\w{2}匹配\w\w和\w\w\w以上,不匹配\w{n,m}匹配n次上m次下\s{1,3}匹配\s,\s\s,\s\s\s,不匹配\s\s\s\s?匹配0或1次5?匹配5或0,不匹配非5和0+匹配一次或多次\S+匹配一个以上\S,不匹配非一个以上\S*匹配0次以上\W*匹配0以上\W,不匹配非N*\W字符定位语法:重复语法语法解释语法例子^定位后面模式开始位置$前面模式位于字符串末端\A前面模式开始位置\z前面模式结束位置\Z前面模式结束位置(换行前)\b匹配一个单词边界\B匹配一个非单词边界转义匹配语法:转义语法涉及字符(语法解释)语法例子“\”+实际字符\.*+?|(){}^$例如:\\匹配字符“\”\n匹配换行\r匹配回车\t匹配水平制表符\v匹配垂直制表符\f匹配换页\nnn匹配一个8进制ASCII\xnn匹配一个16进制ASCII\unnnn匹配4个16进制的Uniode\c+大写字母匹配Ctrl-大写字母例如:\cS-匹配Ctrl+S构造正则表达的方法构造正则表达式需要涉及Regex类,在Regex类中包括:IsMatch()、Replace()、Split()和Match的类;(1)IsMatch()方法;IsMatch()方法实际上是一个返回Bool值得方法,如果测试字符满足正则表达式返回True否则返回False;例1;判断是非成都地区电话号码合法;分析:成都地区电话号码组成028********,前面为固定区号028,后面满足8位数字;设计正则表达式:028\d{8}(解释:028区号固定,后面为8个数字\d组成);程序代码,如图2所示:图2“例1”IsMatch方法是用例(2)Replace()方法;Replace()方法实际上是一种替换的方法,替换匹配正则表达式匹配模式;例2:在发布带有公开电子邮件地址的文章时,替换@位AT避免产生垃圾邮件;分析:首先需要判断文章中电子邮箱地址,然后执行替换设计正则表达式:判断电子邮箱表达式”\w{1,}@w{1,}\\.”;程序代码:如图3所示;图3“例2”Replace方法是用例(3)Split()方法;Split()方法实际上是拆分的方法,根据匹配正则表达式进行拆分储存在字符串数组中;例3:从群发邮件地址中读取所有邮件地址;分析:群发邮件采用“;”作为分割符,需要通过“;”进行拆分程序代码:如图4所示;图4“例3”Split方法是用例构建表达式基本方法构造Regex对象的构造函数包括两个重载,一个是不含参数的构造、另外一个是含有参数的构造函数;基本形式Regex(stringpattern);重载形式Regex(stringpattern,RegexOptions);补充:RegexOptions属于枚举类型,包括IgnoreCase(忽略大小写)、ReghtToLeft(从右向左)、None(默认)、CultureInvariant(忽略区域)、Multline(多行模式)和SingleLine(单行模式);例4,建立一个合法ISBN验证格式;分析:ISBN格式为X-XXXXX-XXX-X;正则表达式格式:\d-\d{5}-\d{3}-\d构造该正则表达式函数RegexISBNRegex=newRegex(表达式,参数为空)详细代码:如图5所示;图5“例4”构造验证函数是用例编写一个检验程序为了方便自己在学习正则表达式和快速检验自己编写表达式语句是否正确,下面提供一个IsMatch()方法正则表达式验证器编写;1.打开VS.NET,选择新建项目中的VisualC#项目的Windows应用程序,取名为“Regex_Tools”;2.然后编写如图6所示的界面图6正则表达式IsMatch方法验证器3.4.然后在该窗体声明中增加正则表达式命名空间声明usingSystem.Text.RegularExpressions;5.编写下列代码o编写一段私有的判断参数的方法,如图7所示;图7私有验证参数判断方法oo编写判断按钮的方法,如图8所示;图8IsMatch验证判断按钮方法oo编写清空按钮的方法,所有的文本框等于空;6.编译该程序,一个简单的正则表达式验证器就成功生成了;(1)“@”符号符下两ows表研究室的火热,当晨在“@”虽然并非C#正则表达式的“成员”,但是它经常与C#正则表达式出双入对。“@”表示,跟在它后面的字符串是个“逐字字符串”,不是很好理解,举个例子,以下两个声明是等效的:stringx=D:\\MyHuang\\MyDoc;stringy=@D:\MyHuang\MyDoc;事实上,如果按如下声明,C#将会报错,因为“\”在C#中用于实现转义,如“\n”换行:stringx=D:\MyHuang\MyDoc;(2)基本的语法字符。\d0-9的数字\D\d的补集(以所以字符为全集,下同),即所有非数字的字符\w单词字符,指大小写字母、0-9的数字、下划线\W\w的补集\s空白字符,包括换行符\n、回车符\r、制表符\t、垂直制表符\v、换页符\f\S\s的补集.除换行符\n外的任意字符[…]匹配[]内所列出的所有字符[^…]匹配非[]内所列出的字符下面提供一些简单的示例:stringi=\n;stringm=3;Regexr=newRegex(@\D);//同Regexr=newRegex(\\D);//r.IsMatch(i)结果:true//r.IsMatch(m)结果:falsestringi=%;stringm=3;Regexr=newRegex([a-z0-9]);//匹配小写字母或数字字符//r.IsMatch(i)结果:false//r.IsMatch(m)结果:true(3)定位字符“定位字符”所代表的是一个虚的字符,它代表一个位置,你也可以直观地认为“定位字符”所代表的是某个字符与字符间的那个微小间隙。^表示其后的字符必须位于字符串的开始处$表示其前面的字符必须位于字符串的结束处\b匹配一个单词的边界\B匹配一个非单词的边界另外,还包括:\A前面的字符必须位于字符处的开始处,\z前面的字符必须位于字符串的结束处,\Z前面的字符必须位于字符串的结束处,或者位于换行符前下面提供一些简单的示例:stringi=Livefornothing,dieforsomething;Regexr1=newRegex(^Livefornothing,dieforsomething$);//r1.IsMatch(i)trueRegexr2=newRegex(^Livefornothing,dieforsome$);//r2.IsMatch(i)falseRegexr3=newRegex(^Livefornothing,dieforsome);//r3.IsMatch(i)truestringi=@Livefornothing,dieforsomething;//多行Regexr1=newRegex(^Livefornothing,dieforsomething$);Console.WriteLine(r1matchcount:+r1.Matches(i).Count);//0Regexr2=newRegex(^Livefornothing,dieforsomething$,RegexOptions.Multiline);Console.WriteLine(r2matchcount:+r2.Matches(i).Count);//0Regexr3=newRegex(^Livefornothing,\r\ndieforsomething$);Console.WriteLine(r3matchcount:+r3.Matches(i).Count);//1Regexr4=newRegex(^Livefornothing,$);Console.WriteLine(r4matchcount:+r4.Matches(i).Count);//0Regexr5=newRegex(^Livefornothing,$,RegexOptions.Multiline);Console.WriteLine(r5matchcount:+r5.Matches(i).Count);//0Regexr6=newRegex(^Livefornothing,\r\n$);Console.WriteLine(r6matchcount:+r6.Matches(i).Count);//0Regexr7=newRegex(^Livefornothing,\r\n$,RegexOptions.Multiline);Console.WriteLine(r7matchcount:+r7.Matches(i).Count);//0Regexr8=newRegex(^Livefornothing,\r$);Console.WriteLine(r8matchcount:+r8.Matches(i).Count);//0Regexr9=newRegex(^Livefornothing,\r$,RegexOptions.Multiline);Console.WriteLine(r9matchcount:+r9.Matches(i).Count);//1Regexr10=newRegex(^dieforsomething$);Console.WriteLine(r10matchcount:+r10.Matches(i).Count);//0Regexr11=newRegex(^dieforsomething$,RegexOptions.Multiline);Console.WriteLine(r11matchcount:+r11.Matches(i).Count);//1Regexr12=newRegex(^);Console.WriteLine(r12matchcount:+r12.Matches(i).Count);//1Regexr13=newRegex($);Console.WriteLine(r13matchcount:+r13.Matches(i).Count);//1Regexr14=newRegex(^,RegexOptions.Multiline);Console.WriteLine(r14matchcount:+r14.Matches(i).Count);//2Regexr15=newRegex($,RegexOptions.Multiline);Console.WriteLine(r15matchcount:+r15.Matches(i).Count);//2Regexr16=newRegex(^Livefornothing,\r$\n^dieforsomething$,RegexOptions.Multiline);Console.WriteLine(r16matchcount:+r16.Matches(i).Count);//1//对于一个多行字符串,在设置了Multilin
本文标题:C#正则表达式整理备忘
链接地址:https://www.777doc.com/doc-3391476 .html