我正在努力,因此需要您的帮助(在linux中).
a)我有一个文件,其中两列用空格隔开(定界符为“”).实际上,我在命令行上运行了一系列管道命令,这给了我如上所述的输出.
aaa bbb
ccc ddd
fff ggg
ccc nnn
fff kkk # there are approx 20,000 such rows.
b)我还有很多其他文件,例如file-1.txt,file-2. txt,file-3.txt.
问题:我需要搜索a节中提到的输出中的每一行.以上.为了说明,我想运行以下内容:
grep 'aaa bbb' file-1 txt file-2.txt file-3 txt
grep 'ccc ddd' file-1 txt file-2.txt file-3 txt
......
20,000 times
.......
但是上面的命令要花很多时间.
题:
如何使用单个命令系列来执行此操作.每当我运行命令时(如下所示),系统仅在行中搜索单个单词,即分别搜索aaa和bbb并给我错误的输出.
例如:
cat < filename > | cut -d "," -f1,2 | xargs -I {} sed '{}' file-1.txt
或使用grep代替sed….
注意:如a点所述,在管道将输出置于空间之前的命令.以上.
任何帮助都感激不尽.
解决方法:
将所有模式(aaa bbb等)存储到文件(patterns.txt)中,每行一个,然后
grep -f patterns.txt file-*.txt
会做的工作.
标签:grep,sed,linux
来源: https://codeday.me/bug/20191120/2043560.html