我正在努力,因此需要您的帮助(在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
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。