我有一个包含文件名(以及它们的完整路径)的文件,我想在所有文件中搜索一个单词。一些伪代码来解释:
grep keyword <all files specified in files.txt>
或者
cat files.txt > grep keyword
cat files txt | grep keyword
问题是我只能让 grep 搜索文件名,而不是实际文件的内容。
cat files.txt | xargs grep keyword
或者
grep keyword `cat files.txt`
或(相当于以前但更难误读)
grep keyword $(cat files.txt)
应该做的伎俩。
陷阱:
如果 files.txt 包含带空格的文件名,则任何一种解决方案都会出错,因为“This is a filename.txt”将被解释为四个文件,“This”、“is”、“a”和“filename.txt”。永远不要在文件名中包含空格的一个很好的理由。
第二个 (cat) 版本可能会导致很长的命令行(超出环境限制时可能会失败)。第一个(xargs)版本自动处理长输入;xargs 提供了几个选项来控制细节。
DevSolar 的两个答案都有效(在 Linux Ubuntu 上测试),但如果可能有很多文件,xargs 版本更可取,因为它将避免遇到命令行长度限制。
所以:
cat files.txt | xargs grep keyword
是要走的路
tr '\n' '\0' <files.txt | LANG=C xargs -r0 grep -F keyword
bash
, ksh
&zsh
版本:
grep keyword $(<files.txt)
上次创建 bash shell 脚本的时间很长,但是您可以将第一个 grep 的结果(查找所有文件名的那个)存储在一个数组中并对其进行迭代,发出更多的 grep 命令。
一个好的起点应该是 bash 脚本指南。