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