我正在使用grep匹配文件中的字符串。下面是一个示例文件:

example one,
example two null,
example three,
example four null,

Grep -i null myfile.txt返回

example two null,
example four null,

如何像这样返回匹配的行及其行号:

  example two null, - Line number : 2
  example four null, - Line number : 4
  Total null count : 2

我知道-c返回总匹配的行,但我不知道如何正确格式化它,在前面添加总空计数,我不知道如何添加行号。

我该怎么办?


当前回答

使用grep -n -i null myfile.txt输出每个匹配项前面的行号。

我不认为grep有一个开关来打印匹配的总行数,但你可以把grep的输出管道到wc来完成:

grep -n -i null myfile.txt | wc -l

其他回答

-n返回行号。

-i代表忽略大小写。仅在不需要进行大小写匹配时使用

$ grep -in null myfile.txt

2:example two null,
4:example four null,

结合awk输出匹配后的行号:

$ grep -in null myfile.txt | awk -F: '{print $2" - Line number : "$1}'

example two null, - Line number : 2
example four null, - Line number : 4

使用命令替换打印出null总数:

$ echo "Total null count :" $(grep -ic null myfile.txt)

Total null count : 2

Grep查找行并输出行号,但不允许“编程”其他东西。如果你想包含任意文本并进行其他“编程”,你可以使用awk,

$ awk '/null/{c++;print $0," - Line number: "NR}END{print "Total null count: "c}' file
example two null,  - Line number: 2
example four null,  - Line number: 4
Total null count: 2

或者只使用shell(bash/ksh)

c=0
while read -r line
do
  case "$line" in
   *null* )  (
    ((c++))
    echo "$line - Line number $c"
    ;;
  esac
done < "file"
echo "total count: $c"

使用grep -n -i null myfile.txt输出每个匹配项前面的行号。

我不认为grep有一个开关来打印匹配的总行数,但你可以把grep的输出管道到wc来完成:

grep -n -i null myfile.txt | wc -l

或者在perl中(为了完整…):

perl -npe 'chomp; /null/ and print "$_ - Line number : $.\n" and $i++;$_="";END{print "Total null count : $i\n"}'

使用-n或——line-number。

查看man grep以获得更多选项。