上下文:grep 用于文件中不同行的多个字符串(即整个文件,而不是基于行的搜索)?
egrep -nH 'Dansk|Norsk|Svenska' file3
或使用ripgrep
rg 'Dansk|Norsk|Svenska' file3
但有一个答案
awk '/Dansk/{a=1}/Norsk/{b=1}/Svenska/{c=1}END{ if (a && b && c) print $0 }' file3
我不明白这个答案。
我明白了awk '/Dansk/{a=1}/Norsk/{b=1}/Svenska/{c=1}
。
我认为现在的问题是使用 awk,在模式匹配时,使用输出行打印行号。
更新:我什至理解这个答案。更新:
几乎接近:
awk '/Dansk/{a=1}/Norsk/{b=1}/Svenska/{c=1}{ if (a || b || c ) print $0; next}1' file3
它返回
Subtitle: 04, Language: da - Dansk, Content: Undefined, Stream id: 0x23,
Subtitle: 05, Language: de - Deutsch, Content: Undefined, Stream id: 0x24,
预期回报是
Subtitle: 04, Language: da - Dansk, Content: Undefined, Stream id: 0x23,
file3
内容:
Disc Title: unknown
Title: 01, Length: 01:33:37.000 Chapters: 33, Cells: 31, Audio streams: 04, Subpictures: 20
Subtitle: 01, Language: ar - Arabic, Content: Undefined, Stream id: 0x20,
Subtitle: 02, Language: bg - Bulgarian, Content: Undefined, Stream id: 0x21,
Subtitle: 03, Language: cs - Czech, Content: Undefined, Stream id: 0x22,
Subtitle: 04, Language: da - Dansk, Content: Undefined, Stream id: 0x23,
Subtitle: 05, Language: de - Deutsch, Content: Undefined, Stream id: 0x24,
(...)
更新。几乎接近。
awk '/Dansk/{a=1}/Norsk/{b=1}/Svenska/{c=1}{ if (a || b || c ) print NR, $0}' file3
但它返回
6 Subtitle: 04, Language: da - Dansk, Content: Undefined, Stream id: 0x23,
7 Subtitle: 05, Language: de - Deutsch, Content: Undefined, Stream id: 0x24,
8 (...)
awk 由一对条件和动作组成,其中条件部分可以是任何算术表达式或模式匹配或一个或多个表达式的结果,所有这些结果都可以是真或假语句;
在这里,给定的示例使用了一对模式匹配和操作,即:
如果在一行中找到这些正则表达式,所有 3 个都执行相同的模式匹配并设置一个临时变量标志。
然后在 END{} 块处,该块仅在处理输入 infile 文件的所有记录/行后运行一次,它只是检查是否设置了所有标志(意味着找到所有 3 种模式,或者在单个line 或 in while 输入文件),然后打印输入文件的最后一行(您可能想要打印 FILENAME 或其他内容)。
回答第二个添加的问题:
这将打印该行至少包含 or 之一
Dansk
的行,Norsk
否则Svenska
打印该命令所做的所有操作都可以写入awk 1 infile
or的行cat infile
。In
x ||y ||z || ...
表示“如果 x OR y OR z OR ... 至少有一个为真”,则做某事,而 inx && y && z &&...
表示“如果 x AND y AND z AND ... 所有这些都为真”,则做某事;“真”是指一个或多个表达式的结果或一个或多个条件评估的真结果。