grep
本身是能够做到的。只需使用标志-f
:
grep -f <patterns> <file>
<patterns>
是每行包含一个模式的文件;并且<file>
是您要在其中搜索内容的文件。
请注意,要强制grep
将每一行视为一个模式,即使每一行的内容看起来像一个正则表达式,您也应该使用 flag -F, --fixed-strings
。
grep -F -f <patterns> <file>
如果您的文件是 CSV,如您所说,您可以这样做:
grep -f <(tr ',' '\n' < data.csv) <file>
例如,考虑文件“a.txt”,其中包含以下几行:
alpha
0891234
beta
现在,文件“b.txt”,包含以下行:
Alpha
0808080
0891234
bEtA
以下命令的输出是:
grep -f "a.txt" "b.txt"
0891234
你根本不需要在for
这里循环;grep
本身就提供了这个功能。
现在使用您的文件名:
#!/bin/bash
patterns="/home/nimish/contents.txt"
search="/home/nimish/another_file.csv"
grep -f <(tr ',' '\n' < "${patterns}") "${search}"
您可以更改','
为文件中的分隔符。