欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

【Linux】一步一步学Linux——fgrep命令(了解)(51)

程序员文章站 2024-02-23 23:39:16
...

00. 目录

01. 命令概述

本指令相当于执行grep指令加上参数"-F",Linux fgrep命令用于查找文件里符合条件的字符串。

fgrep命令是用来搜索 file参数指定的输入文件(缺省为标准输入)中的匹配模式的行。fgrep 命令特别搜索 Pattern 参数,它们是固定的字符串。如果在 File 参数中指定一个以上的文件 fgrep 命令将显示包含匹配行的文件。

fgrep 命令于 grepegrep 命令不同,因为它搜索字符串而不是搜索匹配表达式的模式。fgrep 命令使用快速的压缩算法。$, *, [, |, (, )\等字符串被 fgrep 命令按字面意思解释。这些字符并不解释为正则表达式,但它们在 grep 和 egrep 命令中解释为正则表达式。因为这些字符对于 shell 有特定的含义,完整的字符串应该加上单引号‘ ... ’。. 如果没有指定文件, fgrep 命令假定标准输入。一般,找到的每行都复制到标准输出中去。如果不止一个输入文件,则在找到的每行前打印文件名。

02. 命令格式

用法: fgrep [选项]… PATTERN [FILE]…

03. 常用选项

在每个 FILE 或是标准输入中查找 PATTERN。
PATTERN 是一组由断行符分隔的定长字符串。
例如: fgrep -i 'hello world' menu.h main.c

正则表达式选择与解释:
  -e, --regexp=PATTERN      用 PATTERN 来进行匹配操作
  -f, --file=FILE           从 FILE 中取得 PATTERN
  -i, --ignore-case         忽略大小写
  -w, --word-regexp         强制 PATTERN 仅完全匹配字词
  -x, --line-regexp         强制 PATTERN 仅完全匹配一行
  -z, --null-data           一个 0 字节的数据行,但不是空行

杂项:
  -s, --no-messages         不显示错误信息
  -v, --invert-match        选中不匹配的行
  -V, --version             显示版本信息并退出
      --help                显示此帮助并退出
      --mmap                忽略向后兼容性

Output control:
  -m, --max-count=NUM      匹配的最大数
  -b, --byte-offset         打印匹配行前面打印该行所在的块号码
  -n, --line-number         显示的加上匹配所在的行号
      --line-buffered         刷新输出每一行
  -H, --with-filename       当搜索多个文件时,显示匹配文件名前缀
  -h, --no-filename         当搜索多个文件时,不显示匹配文件名前缀
      --label=LABEL         use LABEL as the standard input file name prefix
  -o, --only-matching       只显示一行中匹配PATTERN 的部分
  -q, --quiet, --silent     不显示所有输出
      --binary-files=TYPE   假定二进制文件的TYPE 类型;
                            TYPE 可以是`binary', `text', 或`without-match'
  -a, --text                等同于 --binary-files=text
  -I                        等同于 --binary-files=without-match
  -d, --directories=ACTION  操作目录的方式;
                            ACTION 可以是`read', `recurse',或`skip'
  -D, --devices=ACTION      操作设备、先入先出队列、套接字的方式;
                            ACTION 可以是`read'或`skip'
  -R, -r, --recursive       等同于 --directories=recurse
      --include=FILE_PATTERN  只查找匹配FILE_PATTERN 的文件
      --exclude=FILE_PATTERN  跳过匹配FILE_PATTERN 的文件和目录
      --exclude-from=FILE   跳过所有除FILE 以外的文件
      --exclude-dir=PATTERN  跳过所有匹配PATTERN 的目录。
  -L, --files-without-match  只打印不匹配FILEs 的文件名
  -l, --files-with-matches  只打印匹配FILES 的文件名
  -c, --count               只打印每个FILE 中的匹配行数目
  -T, --initial-tab         行首tabs 分隔(如有必要)
  -Z, --null                在FILE 文件最后打印空字符

文件控制:
  -B, --before-context=NUM  打印以文本起始的NUM 行
  -A, --after-context=NUM   打印以文本结尾的NUM 行
  -C, --context=NUM         打印输出文本NUM 行
  -NUM                      等同于 --context=NUM
      --color[=WHEN],
      --colour[=WHEN]       使用标志高亮匹配字串;
                            WHEN 可以是`always', `never'或`auto'
  -U, --binary              不要清除行尾的CR 字符(MSDOS 模式)
  -u, --unix-byte-offsets   当CR 字符不存在,报告字节偏移(MSDOS 模式)

‘fgrep’可以使用 ‘grep -F’代替。
不带 FILE 参数,或是 FILE 为 -,将读取标准输入。如果少于两个 FILE 参数
就要默认使用 -h 参数。如果选中任意一行,那退出状态为 0,否则为 1;
如果有错误产生,且未指定 -q 参数,那退出状态为 2。

04. 参考示例

4.1 从文件中所有匹配的字符串

[[email protected] ~]$ fgrep  main test.c
int main()
[[email protected] ~]$ 

4.2 显示文件中包含左括号行的数目

[[email protected] ~]$ fgrep -c '{' test.c
5
[[email protected] ~]$ 

4.3 显示文件中包含右括号行的数目

[[email protected] ~]$ fgrep -c '}' test.c 
5
[[email protected] ~]$ 

4.4 将包含括号的行按照他们在文件中的位置顺序显示出来,使用以下命令

[[email protected] ~]$ egrep {\|} test.c
{
        unsigned char md[16] = { 0 };
        {
        }
}
{
        char result[33] = { 0 };
}
[[email protected] ~]$ 

4.5 只打印匹配FILES 的文件名

[[email protected] ~]$ fgrep -l main test.c
test.c
[[email protected] ~]$ 

05. 附录

参考:【Linux】一步一步学Linux系列教程汇总