0


Notepad++ 使用正则表达式匹配

Notepad++ 使用正则表达式匹配

ctrl+F快捷键,弹出查找对话框;

选中底下的正则表达式即可。

一、常见匹配

1、正则表达式匹配以某字符开头的这一行数据

表达式:
(?:^|\n)字符位置.*     

示例:
(?:^|\n)prompt.*表示以prompt开头的这一行字符串。

2、正则表达式匹配以a字符串开头,b字符串结尾的字符,中间不管

表达式:
a字符串位置(.+?)b字符串位置 ,注意很多字符有特殊意义,要加上\来转义
示例:
匹配以to_date开头,以), 字符串结尾的字符串
to_date(.+?)\), 即可,注意对)进行转义。
注意:
上述说的是以(括号逗号)结尾。

3、只匹配纯数字的字符串

表达式:
^[0-9]+$
解释:
^:匹配行首
[0-9]+:匹配1个或多个数字
$:匹配行尾,总的来说就是匹配一行数字
示例:
只匹配文档中全是数字的某一行,任何符号都不能有。

4、只匹配纯字母的字符串

表达式:
^[A-Za-z]+$
解释:
^:匹配行首
[A-Za-z]+:匹配1个或多个字母
$:匹配行尾,总的来说就是匹配一行字母
示例:
只匹配文档中全是字母的某一行,任何符号都不能有。

5、同时查找多个字符串

表达式:
a|b
示例:
张三|李四|王五
解释:
同时查找文中包含张三、李四、王五字符串所在的行。

二、正则表达式(.+)和(.+?)的区别

1、符号释义

① () 分组符,把括号内的字符当成一个整体处理。

② . 与换行符外的字符都匹配,针对单字符。

③ + 前一字符必须存在,可以重复1次或更多次

④ ?跟在子串后,表示匹配前面的字符串1次或0次,即前一字符可以存在也可以不存在,但是存在只能有一次;

跟在.、+、?后,表示进入非贪婪模式,也称为惰性模式。

2、贪婪/非贪婪模式

正则默认贪婪模式

  1. 贪婪模式

尽可能匹配最长的字符串。贪婪匹配是先看整体字符串是否匹配,如果不匹配,它会去掉字符串中的最后一个字符再次尝试匹配。以此循环,直至匹配成功。

  1. 非贪婪模式

尽可能匹配最短的字符串。惰性匹配是从左侧第一个字符向右匹配,先看是否匹配,若不匹配,就加入右侧下一个字符再次尝试匹配。以此循环,直至匹配成功。

3、实例

存在字符串"<1><123>"

①正则表达式<(.+)>表示尽可能匹配最长的符合规则<字符串>的内容,最终返回"<1><123>"

②正则表达式<(.+?)>表示尽可能匹配最短的符合规则<字符串>的内容,最终返回"<1>"


本文转载自: https://blog.csdn.net/weixin_44259499/article/details/129342053
版权归原作者 Bitup_bitwin 所有, 如有侵权,请联系我们删除。

“Notepad++ 使用正则表达式匹配”的评论:

还没有评论