首页 > 解决方案 > 这两个正则表达式有什么区别?

问题描述

问题的简短直接版本是:为什么这两个正则表达式不同?IE,

href=(['"]).+?\1

对比

href=(['"]).+?['"]或者href=(['"]).+?(['"])


我正在这个网站上练习正则表达式,我正在尝试解决这个级别

http://play.inginf.units.it/#/level/6

我将在此处发布全部内容,以防网站将来出现故障。

           <tr>
                          <a href="javascript:openurl('/Xplore/accessinfo.jsp')" class="topUnderlineLinks">
                                            <A href="/iel5/4235/4079606/04079617.pdf?tp=&arnumber=4079617&isnumber=4079606" class="bodyCopy">PDF</A>(3141 KB)&nbsp;
                        <A href='/xpl/RecentCon.jsp?punumber=10417'>Evolutionary Computation, 2005. The 2005 IEEE Congress on</A><br>
                <td width="33%" ><div align="right"> <a href="/xplorehelp/Help_start.html#Help_searchresults.html" class="subNavLinks" target="blank">Help</a>&nbsp;&nbsp;&nbsp;<a href="/xpl/contactus.jsp" class="subNavLinks">Contact
Kimya ile ilgili çeþitli temel referans
<a href="http://search.epnet.com/login.asp?profile=web&amp;defaultdb=geh"
<a href="http://iimpft.chadwyck.com/" target="_parent">International
<a href="standartlar.html#tse" target="_parent">NFPA Standartlarý</a>
<a href="http://www.gutenberg.org/" target="_parent">Project Gutenberg</a>
<a href="http://proquestcombo.safaribooksonline.com/?portal=proquestcombo&amp;uicode=istanbultek"
<a href="http://www.scitation.org" target="_parent">Scitation</a>
dergilerin listesini görmek için <a href="/online/aip.html">bu yolu</a>
<a href="http://www3.interscience.wiley.com/journalfinder.html"
               <td width="46%"><a href="/xpl/periodicals.jsp" class="dropDownNav" accesskey="j">Journals &amp; Magazines
               <td><a href="http://www.ieee.org/products/onlinepubs/resources/XploreTutorial.pdf" class="dropDownNav">IEEE Xplore Demo</a></td>
                          &nbsp;|&nbsp;&nbsp; <a href="/xpl/tocalerts_signup.jsp" class="topUnderlineLinks">Alerts</a>
                        <A href='/xpl/RecentCon.jsp?punumber=10417'>Evolutionary Computation, 2005. The 2005 IEEE Congress on</A><br>
                                    <a href="/search/srchabstract.jsp?arnumber=1554748&isnumber=33079&punumber=10417&k2dockey=1554748@ieeecnfs&query=%28+grammatical+evolution%3Cin%3Eti+%29&pos=9" class="bodyCopy">Abstract</a>
                                          <td><a href="history.jsp">View Session History</a></td>
                                          <td><a href="advsearch.jsp">New Search</a></td>
<a href="http://web5s.silverplatter.com/webspirs/start.ws?customer=kaynak"
<a href="standartlar.html#tse">Türk Standartlarý</a>
<a href="http://isiknowledge.com" target="_parent">Web of Science</a>
<a href='deneme.html#bg'>Butler Group </a>veritabanýna 31 Mart 2007 tarihine kadar deneme eriþimi alýnmýþtýr. &nbsp;<span class="tarih">(19.03.2007)</span> 
<a href='deneme.html#ps'>Productscan</a> veritabanýna 31 Mart 2007 tarihine kadar deneme eriþimi alýnmýþtýr. &nbsp;<span class="tarih">(19.03.2007)</span> 

我应该匹配这样的文本

href="history.jsp"

那就是我需要匹配上面文本中的任何href。

现在根据解决方案,似乎答案是href=(['"]).+?\1

但是最后一个反向引用,如果我不使用它并重复正则表达式组(我希望括号称为组,如果我错了,请纠正我),为什么我会得到不同的结果?也就是说,如果我使用它,我会得到错误的结果。href=(['"]).+?['"]或者href=(['"]).+?(['"])

标签: regexregex-groupbackreference

解决方案


反向引用必须匹配捕获组匹配的相同内容。所以第一个正则表达式将匹配

"abcd"

或者

'abcd'

第二个版本没有链接匹配的两端,所以它也会匹配以下内容:

"abcd'

或者

'abcd"

所以带有反向引用的版本只匹配被相同类型引号包围的字符串。

如果您在字符串中嵌入了引号,则这种差异很重要,例如

some text "<div id='foo'>" more text

带有反向引用的版本将匹配"<div id='foo'>",但没有反向引用的版本将匹配"<div id='


推荐阅读