[英]How can I grep in a loop?
我有一个包含单独行文本的文件。
text1
text2
text3
textN
我有一个包含许多文件的目录。 我想grep这个特定目录中的每一行。 有什么简单的方法可以做到这一点?
没有必要循环,你可以使用带-f
选项的grep
来从文件中获取模式:
grep -f pattern_file files*
从man grep
:
-f FILE, - file = FILE
从FILE获取模式,每行一个。 空文件包含零模式,因此不匹配任何内容。 (-f由POSIX指定。)
$ cat a1
hello
how are you?
$ cat a2
bye
hello
$ cat pattern
hello
bye
$ grep -f pattern a*
a1:hello
a2:bye
a2:hello
你也可以使用标准的bash循环:
for i in text*; do grep "pattern" $i; done
甚至更好的选择没有循环:
grep "pattern" text*
如果在*
之后按Tab键,那么shell会将其扩展为满足条件的文件。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.