字符匹配语法:
字符语法 | 语法解释 | 语法例子 |
---|---|---|
\d | 匹配数字(0~9) | ‘\d’匹配8,不匹配12; |
\D | 匹配非数字 | ‘\D’匹配c,不匹配3; |
\w | 匹配任意单字符 | ‘\w\w’ 匹配A3,不匹配@3; |
\W | 匹配非单字符 | ‘\W’匹配@,不匹配c; |
\s | 匹配空白字符 | ‘\d\s\d’匹配3 d,不匹配abc; |
\S | 匹配非空字符 | ‘\S\S\S’匹配A#4,不匹配3 d; |
. | 匹配任意字符 | ‘....’匹配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 |
示例:
读取文件内容和分析,文件格式如下:
string[] lines = File.ReadAllLines(Server.MapPath("type.txt"), Encoding.UTF8); |
运行的结果:
所以说,正则表达式是很强大的,尤其是在批量格式化的时候很方便使用!!
附:
替换html代码中的关键词,但不能是img a标签中的内容:
html=Regex.Replace(html,@"(?<!(<img[^>]*?)|<a\b[^>]*?>[^<>]*?)(设计|技能)","<a href=\"http://www.test.com\">$2</a>");
重复匹配需要的内容:
var txt="[CQ:image,file=A7D637E6F29F199D7D2ADDEB2A1D21B4.png][CQ:image,file=A7D637E6F29F199D7D2ADDEB2A1D21B5.png]adad"; Regex reg=new Regex(@"\[CQ:image,file=(?<filename>[^\s\r\n\]]+)\]", RegexOptions.IgnoreCase); MatchCollection matches = reg.Matches(txt); if(matches.Count>0){ matches.Count.Dump(); foreach (Match match in matches) { match.Groups["filename"].Value.Dump(); } } else "匹配失败".Dump();
更多正则表达式参考:http://blog.csdn.net/dl020840504/article/details/8880603