在计算字符串数时,我得到了很多零。我需要对多个文件执行此操作。我也在尝试在shell脚本中做到这一点。但我不介意一个命令,它将输出计数数量与文件名。
这目前是可行的,但是对于90个文件来说太手动了:
less filename.log.2014-11-01.gz | grep -wc "burgers for 1 dollar"
count: 5678使用上面的命令,它可以工作。但是,当我多次尝试将此代码添加到shell脚本中并运行该脚本时,它是否返回0?这是不正确的:
#!/bin/bash
less filename.log.2014-11-01.gz | grep -wc "burgers for 1 dollar"
less filename.log.2014-11-02.gz | grep -wc "burgers for 1 dollar"
less filename.log.2014-11-03.gz | grep -wc "burgers for 1 dollar"
less filename.log.2014-11-04.gz | grep -wc "burgers for 1 dollar"输出:
0
0
0
0
0发布于 2015-01-31 15:26:25
less是一个交互式查看器,而不是用于解压gzipped文件的命令。请尝试使用gzcat或zcat。
(是的,有一些方法可以让less在幕后运行gzcat,但这取决于并不总是可用的配置,您已经清楚地注意到了。)
此外,您的代码将从简单的循环中受益良多。
for log in filename.log.2014-11-0[1234].gz; do
printf '%s:' "$log"
gzcat "$log" | grep -wc 'burgers for 1 dollar'
done我将文件名添加到每个输出行,以提高可用性。当然,在这种情况下,您希望
gzgrep -wc 'burgers for 1 dollar' filename.log.2014-11-0[1234].gz但是,一些旧版本的gzgrep在公开底层grep命令的完整功能方面做得并不完美,因此如果只有gzgrep的旧版本,则可能需要恢复到循环。
https://stackoverflow.com/questions/28249232
复制相似问题