私はいくつかの文字列を含むファイルをより頻繁に見つけることを認めます。
現在私はそうします:
grep -rl string1 | xargs grep -l string2 | xargs grep -l string3
これを行うためのツールはありますか?
これはまたはgrep
です。string1
string2
string3
grep -rl -e string1 -e string2 -e string3
string1
string2
and を含むファイルが必要ですstring3
が、必ずしも同じ行にある必要はありません。
grep
たぶん現代人の一人( )がag/ack/rg/sift
これを行うことができますか?
ベストアンサー1
次のように使用できますgrep
。
grep -rzlP '(?s)(?=.*?string1)(?=.*?string2)(?=.*?string3)' .
(?s)
既知の「dot-all」は次のとおりです。grepドットが.
新しい行文字と一致することを許可します。\n
(?=.*?pattern)
:順方向予測は.
0回以上出現し、*
欲張りのないすべての文字と一致し、その後にパターン(string1
、、、string2
...)が続きます。
次の関数を作成できます(POSIX bash
&zsh
)。
mgrep() { eval grep -rzlP $(printf ''\''(?s)';
printf '(?=.*?'\''"$%d"'\'')' $(eval echo {1..$#}); printf ''\''') . ; }
次に、次のように呼び出すと、現在の作業ディレクトリのすべての内容を含むファイルが再帰的に検索されます。模様存在する。
mgrep string1 string2 string3
grep
また、基本的にサポートされているすべてのタイプのパターンを処理します(grep
必要に応じて機能のオプションを事前に調整してください。)。
mgrep string 'pattern with space' '\d+' [0-9] [...]