• .net中的正则表达式使用高级技巧 (二)


    上一篇:.net中的正则表达式使用高级技巧 (一)

    正则表达式中的组是很重要的一个概念,它是我们通向高级正则应用的的桥梁

    组的概念

    一个正则表达式匹配结果可以分成多个部分,这就是组(Group)的目的。能够灵活的使用组后,你会发现Regex真是很方便,也很强大。

    先举个例子  

            public static void Main()
            
    {    
                
    string s = "2005-2-21";
                Regex reg 
    = new Regex(@"(?<y>\d{4})-(?<m>\d{1,2})-(?<d>\d{1,2})",RegexOptions.Compiled);
                Match match 
    = reg.Match(s);
                
    int year =  int.Parse(match.Groups["y"].Value);
                
    int month = int.Parse(match.Groups["m"].Value);
                
    int day = int .Parse(match.Groups["d"].Value);
                DateTime time 
    = new DateTime(year,month,day);
                Console.WriteLine(time);
                Console.ReadLine();
            }

    以上的例子通过组来实现分析一个字符串,并把其转化为一个DateTime实例,当然,这个功能用DateTime.Parse方法就能很方便的实现。

    在这个例子中,我把一次Match结果用(?<name>)的方式分成三个组"y","m","d"分别代表年、月、日。

    现在我们已经有了组的概念了,再来看如何分组,很简单的,除了上在的办法,我们可以用一对括号就定义出一个组,比如上例可以改成  

            public static void Main()
            
    {    
                
    string s = "2005-2-21";
                Regex reg 
    = new Regex(@"(\d{4})-(\d{1,2})-(\d{1,2})",RegexOptions.Compiled);
                Match match 
    = reg.Match(s);
                
    int year =  int.Parse(match.Groups[1].Value);
                
    int month = int.Parse(match.Groups[2].Value);
                
    int day = int .Parse(match.Groups[3].Value);
                DateTime time 
    = new DateTime(year,month,day);
                Console.WriteLine(time);
                Console.ReadLine();
            }


    从上例可以看出,第一个括号对包涵的组被自动编号为1,后面的括号依次编号为2、3…… 

            public static void Main()
            
    {    
                
    string s = "2005-2-21";
                Regex reg 
    = new Regex(@"(?<2>\d{4})-(?<1>\d{1,2})-(?<3>\d{1,2})",RegexOptions.Compiled);
                Match match 
    = reg.Match(s);
                
    int year =  int.Parse(match.Groups[2].Value);
                
    int month = int.Parse(match.Groups[1].Value);
                
    int day = int .Parse(match.Groups[3].Value);
                DateTime time 
    = new DateTime(year,month,day);
                Console.WriteLine(time);
                Console.ReadLine();
            }

    再看上例,我们用(?<数字>)的方式手工给每个括号对的组编号,(注意我定义12的位置时不是从左到右定义的)

    通过以上三例,我们知道了给Regex定义Group的三种办法以及相应的引用组匹配结果的方式。

    然后,关于组定义,还有两点请注意:
    1、因为括号用于定义组了,所以如果要匹配"("")",请使用"\(""\)"(关于所有特殊字符的定义,请查看相关Regex expression帮助文档)
    2、如果定义Regex时,使用了ExplicitCapture选项,则第二个例子不会成功,因为此选项要求显式定义了编号或名字的组才捕获并保存结果,如果你没有定义ExplicitCapture选项,而有时又定义了类式于(A|B)这样的部分在表达式,而这个(A|B)你又并不想捕获结果,那么可以使用“不捕获的组”语法,即定义成(?:)的方式,针对于(A|B),你可以这样来定义以达到不捕获并保存它到Group集合中的目的--(?:A|B) 

    上面内容仅讨论了一般的组,组还有很多的花样,很多高级的功能,下一篇将试图带您体验一番其中洞天。

    下一篇:.net中的正则表达式使用高级技巧 (三) 
                    .net中的正则表达式使用高级技巧 (四) 

  • 相关阅读:
    AtomicLong与LongAdder的区别
    记录Vmware Workstation及Centos6.8 的安装
    java.lang.NoSuchMethodError问题处理
    java读取UTF-8的txt文件发现开头的一个字符问题
    Java多线程之内存可见性和原子性:Synchronized和Volatile的比较
    关于怎么解决java.lang.NoClassDefFoundError错误
    使用SFTP工具相关问题
    resin中关于url rewrite来传递jsessionid的问题
    Linux常用命令
    Jenkins简单安装及配置(Windows环境)
  • 原文地址:https://www.cnblogs.com/think/p/regexexpressionsyntax2.html
Copyright © 2020-2023  润新知