例如,如果我使用 GREP 命令从 1000 个文件中搜索/检查关键字/字符串;那么是否有任何选项/方式来查看/显示 GREP 命令处理的文件的百分比或数量......?
只是我想知道完成搜索过程还需要多长时间。
请帮忙
试试awk
。这将打印一条消息,提示正在处理的文件号,然后是匹配模式的行。我在这里选择了模式作为字符 p,因为这对我的测试来说很容易。您可以根据您的目的用任何有效的正则表达式替换。
awk -v PAT="p" 'FNR == 1 { n++; printf "Processing %d of %d files\n", n, ARGC - 1 >> "/dev/stderr"} FILENAME ~ /.gz$/ {print "Skipping gz file: ", FILENAME; nextfile} /PAT/'
解释
awk -v PAT="p" '
FNR == 1 { # Every first line of the file
n++; # Counter for file being processed
printf "Processing %d of %d files\n", # Print message
n, # file number
ARGC - 1 # Number of files on CLI
>> "/dev/stderr" # Redirect to stderr
}
FILENAME ~ /.gz$/ { # Skip gunzip files
print "Skipping gz file: ", FILENAME;
nextfile # move to next file
}
/PAT/ # Pattern to print
'
更新
更新了代码以在处理时跳过 gunzip (.gz) 文件。