我试图使用grep来匹配包含两个不同字符串的行。我已经尝试了以下方法,但这匹配了包含不是我想要的string1或string2的行。
grep 'string1\|string2' filename
那么我如何匹配与grep只包含两个字符串的行?
我试图使用grep来匹配包含两个不同字符串的行。我已经尝试了以下方法,但这匹配了包含不是我想要的string1或string2的行。
grep 'string1\|string2' filename
那么我如何匹配与grep只包含两个字符串的行?
当前回答
当两个字符串按顺序排列时,在grep命令中放入一个模式:
$ grep -E "string1(?.*)string2" file
例如,在名为Dockerfile的文件中包含以下行:
FROM python:3.8 as build-python
FROM python:3.8-slim
要获取包含字符串的行:FROM python和as build-python,然后使用:
$ grep -E "FROM python:(?.*) as build-python" Dockerfile
然后输出将只显示包含这两个字符串的行:
FROM python:3.8 as build-python
其他回答
正则表达式中的|操作符表示或。也就是说,string1或string2将匹配。你可以这样做:
grep 'string1' filename | grep 'string2'
它将把第一个命令的结果输送到第二个grep中。这应该只会给出两者都匹配的行。
我觉得这就是你想要的
grep -E "string1|string2" filename
我认为答案是这样的:
grep 'string1.*string2\|string2.*string1' filename
只匹配两者都存在的情况,而不是其中一个或另一个或两者都存在的情况。
你可以尝试这样做:
(pattern1.*pattern2|pattern2.*pattern1)
你的方法几乎很好,只是少了一个-w
grep -w 'string1\|string2' filename
ripgrep
下面是使用rg的例子:
rg -N '(?P<p1>.*string1.*)(?P<p2>.*string2.*)' file.txt
它是最快的抓取工具之一,因为它建立在Rust的正则引擎之上,该引擎使用有限自动机、SIMD和积极的文字优化来使搜索非常快。
使用它,特别是在处理大量数据时。
参见GH-875中的相关功能请求。