我有一个包含大量字符串的日志文件.我想从这个文件(查找和替换),除了开头的任何字符串删除一切:phone=
与结束Digits=1
例如: phone=97212345678&step=1&digits=1
要找到我正在使用的字符串(phone=.*digits=1)
,它的工作原理!但我没有找到正则表达式选择除了这个字符串之外的一切,并清除它们.
样本文件.
为了消除任何东西,但具体的文字,您需要使用.*(text_you_need_to_keep).*
与.
匹配一个换行符.
在Notepad ++中,使用
查找:.*(phone=\S*?digits=1).*
替换:$1
注意:.必须检查匹配换行符选项.
我使用\S*?
而不是.*
捕获模式内部,因为你只想匹配任何非空白字符,尽可能少phone=
到最接近digits
..*
过于贪婪,可能会在DOTALL选项为ON的情况下延伸多行.
UPDATE
如果要在文本中保留多次出现的模式,可以在Notepad ++中使用
.*?(phone=\S*?digits=1)
替换为$1\n
.这样,您将删除所有不需要的子字符串,但是在最后一次出现必要的子模式之后.
您需要以manaully或者删除最后一个块
FIND: (phone=\S*?digits=1).* REPLACE: $1