我正在使用 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 返回总匹配行,但我不知道如何正确格式化它以在前面添加 total null count
,而且我不知道如何添加行号。
我能做些什么?
-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
使用命令替换打印出总空计数:
$ echo "Total null count :" $(grep -ic null myfile.txt)
Total null count : 2
使用 -n
或 --line-number
。
查看 man grep
了解更多选项。
使用 grep -n -i null myfile.txt
输出每个匹配项前面的行号。
我不认为 grep 有一个开关来打印匹配的总行数,但是您可以将 grep 的输出通过管道传输到 wc 来完成此操作:
grep -n -i null myfile.txt | wc -l
或改用 awk
:
awk '/null/ { counter++; printf("%s%s%i\n",$0, " - Line number: ", NR)} END {print "Total null count: " counter}' file
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"
或在 perl 中(为了完整性......):
perl -npe 'chomp; /null/ and print "$_ - Line number : $.\n" and $i++;$_="";END{print "Total null count : $i\n"}'
请参阅此链接以获取 linux 命令 linux http://linuxcommand.org/man_pages/grep1.html
要显示行号、代码行和文件,请在终端或 cmd、GitBash 中使用此命令(由终端提供支持)
grep -irn "YourStringToBeSearch"
只是想我将来可能会对你有所帮助。要搜索多个字符串和输出行号并浏览输出,请键入:
egrep -ne 'null|three'
将会呈现:
2:example two null,
3:example three,
4:example four null,
egrep -ne 'null|three' | less
将在较少的会话中显示输出
HTH君
不定期副业成功案例分享
awk95: syntax error at source line context is >>> ' <<< missing } awk95: bailing out at source line 1
-ni
的骑士就是你记住这个技巧的方式