本指令至关于执行grep指令加上参数"-F",Linux fgrep命令用于查找文件里符合条件的字符串。linux
fgrep命令是用来搜索 file参数指定的输入文件(缺省为标准输入)中的匹配模式的行。fgrep 命令特别搜索 Pattern 参数,它们是固定的字符串。若是在 File 参数中指定一个以上的文件 fgrep 命令将显示包含匹配行的文件。web
fgrep 命令于 grep 和 egrep 命令不一样,由于它搜索字符串而不是搜索匹配表达式的模式。fgrep 命令使用快速的压缩算法。$, *, [, |, (, )
和\
等字符串被 fgrep 命令按字面意思解释。这些字符并不解释为正则表达式,但它们在 grep 和 egrep 命令中解释为正则表达式。由于这些字符对于 shell 有特定的含义,完整的字符串应该加上单引号‘ ... ’
。. 若是没有指定文件, fgrep 命令假定标准输入。通常,找到的每行都复制到标准输出中去。若是不止一个输入文件,则在找到的每行前打印文件名。正则表达式
用法: fgrep [选项]… PATTERN [FILE]…算法
在每一个 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。
4.1 从文件中全部匹配的字符串shell
[deng@localhost ~]$ fgrep main test.c int main() [deng@localhost ~]$
4.2 显示文件中包含左括号行的数目svg
[deng@localhost ~]$ fgrep -c '{' test.c 5 [deng@localhost ~]$
4.3 显示文件中包含右括号行的数目ui
[deng@localhost ~]$ fgrep -c '}' test.c 5 [deng@localhost ~]$
4.4 将包含括号的行按照他们在文件中的位置顺序显示出来,使用如下命令spa
[deng@localhost ~]$ egrep {\|} test.c { unsigned char md[16] = { 0 }; { } } { char result[33] = { 0 }; } [deng@localhost ~]$
4.5 只打印匹配FILES 的文件名.net
[deng@localhost ~]$ fgrep -l main test.c test.c [deng@localhost ~]$
参考:【Linux】一步一步学Linux系列教程汇总unix