首页 > 解决方案 > 编写 Linux Bash 脚本,根据行中的字数打印 grep 输出

问题描述

我正在尝试为 bash shell 编写脚本。我得到了4个参数:

  1. 目录的路径
  2. 文件的扩展名
  3. 一个字
  4. 一个号码

我必须查找路径的子目录的所有文件和文件,以查找具有给定扩展名的文件。然后,在文件中查找与给定单词匹配的行,但前提是该行中的单词数大于或等于提供的数字。
例如:
如果localDirectory有:image.png script.sh text.txt
并且text.txt有:

This is a text file
It contains many words
This is an example for a simple text file

然后给出命令:./example.sh localDirectory txt text 7
我应该输出:This is an example for a simple text file

目前,我的脚本如下所示:

if [ "$#" -ne 4 ];
then
  echo "Not enough parameters"
  exit 1
fi
find $1 -name "*.$2" -exec grep -wi $3  {} \;

对于前 3 个目标,它工作得很好,我只是不知道现在如何过滤结果,使得该行的单词数大于或等于 $4。

我当然可以创建一个新文件并在那里输出,然后从中读取并仅打印相关行,但我宁愿这样做而不创建新文件。

我对 shell 脚本很陌生。

有任何想法吗?

标签: linuxbashshell

解决方案


使用awk以便您可以测试NF(行中的字段数)。

还要记住引用所有变量。

find "$1" -name "*.$2" -exec awk -v word="${3,,}" -v count="$4" 'NF >= count && tolower($0) ~ word' {} +

${3,,}转换$3为小写,tolower($0)并将文件行转换为小写,因此比较它们使其不区分大小写。


推荐阅读