Notepad++ 使用正则表达式匹配的方法
<div id="navCategory"><h5 class="catalogue">目录</h5><ul class="first_class_ul"><li><a href="#_label0">Notepad++ 使用正则表达式匹配</a></li><li><a href="#_label1">一、常见匹配</a></li><ul class="second_class_ul"><li><a href="#_lab2_1_0">1、正则表达式匹配以某字符开头的这一行数据</a></li><li><a href="#_lab2_1_1">2、正则表达式匹配以a字符串开头,b字符串结尾的字符,中间不管</a></li><li><a href="#_lab2_1_2">3、只匹配纯数字的字符串</a></li><li><a href="#_lab2_1_3">4、只匹配纯字母的字符串</a></li><li><a href="#_lab2_1_4">5、同时查找多个字符串</a></li></ul><li><a href="#_label2">二、正则表达式(.+)和(.+?)的区别</a></li><ul class="second_class_ul"><li><a href="#_lab2_2_5">1、符号释义</a></li><li><a href="#_lab2_2_6">2、贪婪/非贪婪模式</a></li><li><a href="#_lab2_2_7">3、实例</a></li></ul></ul></div><p class="maodian"><a name="_label0"></a></p><h2>Notepad++ 使用正则表达式匹配</h2><blockquote><p><kbd>ctrl</kbd>+<kbd>F</kbd>快捷键,弹出查找对话框;</p>
<p>选中底下的正则表达式即可。</p></blockquote>
<p class="maodian"><a name="_label1"></a></p><h2>一、常见匹配</h2>
<p class="maodian"><a name="_lab2_1_0"></a></p><h3>1、正则表达式匹配以某字符开头的这一行数据</h3>
<div class="jb51code"><pre class="brush:plain;">表达式:
(?:^|\n)字符位置.*
示例:
(?:^|\n)prompt.*表示以prompt开头的这一行字符串。</pre></div>
<p class="maodian"><a name="_lab2_1_1"></a></p><h3>2、正则表达式匹配以a字符串开头,b字符串结尾的字符,中间不管</h3>
<div class="jb51code"><pre class="brush:plain;">表达式:
a字符串位置(.+?)b字符串位置 ,注意很多字符有特殊意义,要加上\来转义
示例:
匹配以to_date开头,以), 字符串结尾的字符串
to_date(.+?)\), 即可,注意对)进行转义。
注意:
上述说的是以(括号逗号)结尾。</pre></div>
<p class="maodian"><a name="_lab2_1_2"></a></p><h3>3、只匹配纯数字的字符串</h3>
<div class="jb51code"><pre class="brush:plain;">表达式:
^+$
解释:
^:匹配行首
+:匹配1个或多个数字
$:匹配行尾,总的来说就是匹配一行数字
示例:
只匹配文档中全是数字的某一行,任何符号都不能有。</pre></div>
<p class="maodian"><a name="_lab2_1_3"></a></p><h3>4、只匹配纯字母的字符串</h3>
<div class="jb51code"><pre class="brush:plain;">表达式:
^+$
解释:
^:匹配行首
+:匹配1个或多个字母
$:匹配行尾,总的来说就是匹配一行字母
示例:
只匹配文档中全是字母的某一行,任何符号都不能有。</pre></div>
<p class="maodian"><a name="_lab2_1_4"></a></p><h3>5、同时查找多个字符串</h3>
<div class="jb51code"><pre class="brush:plain;">表达式:
a|b
示例:
张三|李四|王五
解释:
同时查找文中包含张三、李四、王五字符串所在的行。</pre></div>
<p class="maodian"><a name="_label2"></a></p><h2>二、正则表达式(.+)和(.+?)的区别</h2>
<p class="maodian"><a name="_lab2_2_5"></a></p><h3>1、符号释义</h3>
<p>① () 分组符,把括号内的字符当成一个整体处理。</p>
<p>② . 与换行符外的字符都匹配,针对单字符。</p>
<p>③ + 前一字符必须存在,可以重复1次或更多次</p>
<p>④ ?跟在子串后,表示匹配前面的字符串1次或0次,即前一字符可以存在也可以不存在,但是存在只能有一次;</p>
<p>跟在.、+、?后,表示进入非贪婪模式,也称为惰性模式。</p>
<p class="maodian"><a name="_lab2_2_6"></a></p><h3>2、贪婪/非贪婪模式</h3>
<blockquote><p>正则默认贪婪模式</p></blockquote>
<p>1.贪婪模式</p>
<p>尽可能匹配最长的字符串。贪婪匹配是先看整体字符串是否匹配,如果不匹配,它会去掉字符串中的最后一个字符再次尝试匹配。以此循环,直至匹配成功。</p>
<p>2.非贪婪模式</p>
<p>尽可能匹配最短的字符串。惰性匹配是从左侧第一个字符向右匹配,先看是否匹配,若不匹配,就加入右侧下一个字符再次尝试匹配。以此循环,直至匹配成功。</p>
<p class="maodian"><a name="_lab2_2_7"></a></p><h3>3、实例</h3>
<p>存在字符串"<1><123>"</p>
<p>①正则表达式<(.+)>表示尽可能匹配最长的符合规则<字符串>的内容,最终返回"<1><123>"</p>
<p>②正则表达式<(.+?)>表示尽可能匹配最短的符合规则<字符串>的内容,最终返回"<1>"</p>
頁:
[1]