I've long list of generated reports which I want to filter. The report is something like this:
Report Name
Report Date
Blah blah blah
Blah: WORD1
Blah blah
blah blah: WORD2
blah blah
I'm trying to use ag (PCRE regex) or rg (rust regex) and find all files which contains WORD1 AND WORD2 in different places of the file (contains new line).
I've already search SX and found these which didn't work:
> ag (?=.*WORD1)(?=.*WORD2)
> ag (?=.*WORD1)((.|\n)*)(?=.*WORD2)
As @WiktorStribiżew pointed out, the ag uses PCRE. Sorry for the mistake.
my expected output is:
blah blah: WORD2
or just the list of matched files.
p.s. currently I've managed to using this:
> ag "WORD2" $(ag -l "WORD1")
You may use a PCRE pattern with ag:
(?s)^(?=.*WORD1)(?=.*WORD2).*\n\K(?-s).*WORD2
See the regex demo.
Details:
(?s) - a DOTALL modifier ON (. matches line break chars)^ - start of string(?=.*WORD1)  - there must be WORD1 somewhere in the string(?=.*WORD2) - there must be WORD2 somewhere in the string.* - any 0+ chars, as many as possible, up to the last occurrence of the subsequent subpatterns (if you use a lazy *? quantifier, .*? will match 0+ chars as few as possible up to the first occurrence of the subsequent subpatterns)\n - a newline\K - match reset operator discarding the currently matched text(?-s) - DOTALL mode disabled (. does not match line breaks).*WORD2 - any 0+ chars other than line break chars, as many as possible, and then WORD2.The question mentions this pattern, which works:
ag "WORD2" $(ag -l "WORD1")
But only WORD2 will be highlighted in color. I prefer:
ag 'WORD1|WORD2' --passthru -C3 $(ag -l "WORD1" $(ag -l "WORD2"))
This gives three lines on either side of the matches and highlights both WORD1 and WORD2.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With