zoukankan      html  css  js  c++  java
  • 正则表达式中的反向引用

    1.反向引用需要使用到分组,分组就是使用()括起来的部分为一个整体,在进行分组匹配时的原则是:由外向内,由左向右


    2.反向引用如:1,2等
              1:表示的是引用第一次匹配到的()括起来的部分
              2:表示的是引用第二次匹配到的()括起来的部分
     
              (1)例:
                   String regex = "^(\d)\1$";
                   首先这里是匹配两位,d一位,1又引用d一位 这里的1会去引用(d)匹配到的内容,因为(d)是第一次匹配到的内容。
                  如:str = "22"时,(\d)匹配到2,所以1引用(\d)的值也为2,所以str="22"能匹配
                        str = "23"时,(\d)匹配到2,因为1引用(\d)的值2,而这里是3,所以str="23"不能匹配
              (2)例:
                   String regex = "^(\d)\1[0-9](d)1{2}";
                   注意在后面第二个(d)1{2}中的1,这里的1并不会去匹配他前面的(d),而是匹配第一个(\d),
                   如:第一个(d)为3时,则第一个1也为3,同样最后那个1也为3,所以结果可以是335933,332533
                        而不是336444,339888
                 
     
              (3)例:
                   String regex = " ^(d)1[0-9](d)2{2}$";
                   这里使用了2引用第二次匹配到的分组,这里第二次匹配的分组为2前面的(d), 这里的{2}指的是2的值出现两次
                   如:第一个(d)为4时,1引用第1个(d)也为4,第二个(d)为5时,2引用第二个(d)为5,所以结果可以是:447555,440222
              
              
              
     
              (4)例:
                   String regex = " ^((d)3)1[0-9](d)2{2}$";
                   当匹配中的分组有嵌套时,是从外向里匹配的,其次在由左向右匹配
                   这里主要是分析匹配到分组的顺序,首先匹配((d)3)这整个部分,其次匹配((d)3)里面的(d),第三次匹配时最后一个2前面的(d)
                   如:如((d)3)中的(d)为2时,((d)3)的值为23,此时1为((d)3)的值1,而2引用((d)3)中的(d)的值3,第三个(d)为5时,此时3引用第三个(d)的值5,所以结果可以有:23238522,23230522,
              
                   
  • 相关阅读:
    rake db:migrate学会的一些tips
    不提拔你,就因为你只想把工作做好
    jira4r:使用Ruby操作JIRA
    <当下的力量>读书笔记
    Your template was not saved as valid UTF8. 解决方法
    lxml.etree 教程3:Elements carry attributes as a dict
    Ruby目录及文件操作
    体验最火的敏捷SCRUM!(网络直播课程 免费)
    UMLonline技术沙龙:体验一把SCRUM(20121027 广州 免费)
    视频分享:挨踢项目求生法则(1)——团队建设篇
  • 原文地址:https://www.cnblogs.com/1549983239yifeng/p/14067260.html
Copyright © 2011-2022 走看看