我有一个文件中的文件列表。该列表很大,并且文件名是非标准的:这意味着,有些文件名包含空格、非 ascii 字符、引号、单引号...
所以,通过那个huge不能选择将文件列表作为 grep 参数:
- 因为我不确定我不会超过linux允许的参数长度。我想我可以通过对参数进行分区来解决这个问题
xargs
, 尽管。
- 因为转义这些字符很复杂。如果我想将文件名括在双引号中,而该文件名恰好有双引号,那么我就有麻烦了。所以我需要转义一些字符。整个事情看起来很复杂,我不想走那条路。
必须有一种更简单的方法:如何告诉 grep 使用我的文件列表作为 grep 的来源文件?我认为由于 shell 不会处理文件列表,因此转义和参数长度不再是问题。问题是grep是否支持这种操作方式,我在文档中一直找不到。
据我所知,GNU grep 不支持这一点。你有几个选择。
使用 bash 循环来解析文件列表
这是@fedorqui提供的解决方案
while read file; do
grep "$PATTERN" "$file"
done < file_with_list_of_files
使用 xargs 一次将多个文件传递给 grep
这里我告诉 xargs 将 10 个文件名传递给 grep
PATTERN='^$' # searching for blank lines
xargs -n 10 -d '\n' grep "$PATTERN" < file_with_list_of_files
使用 xargs 将多个文件一次传递给 grep,处理文件名中的换行符
如上所述,但使用空终止行
PATTERN='^$' # searching for blank lines
tr '\n' '\0' file_with_list_of_files
xargs -n 10 -0 grep "$PATTERN" < file_with_list_of_files
Edit:正确处理空白Edit2:删除产生乱码输出的示例,添加处理换行符的示例
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)