Linux文本匹配命令grep与fgrep使用全解

作者&投稿:诸齐 (若有异议请与网页底部的电邮联系)
~   Linux中grep与fgrep命令的使用,两个命令的使用都与文本的搜索与匹配相关,是Linux入门学习中的基础知识,接下来是我为大家收集的Linux文本匹配命令grep与fgrep使用全解,希望能帮到大家。
  Linux文本匹配命令grep与fgrep使用全解
  grep

  grep (global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。Unix的grep家族包括grep、egrep和fgrep。egrep和fgrep的命令只跟grep有很小不同。egrep是grep的扩展,支持更多的re元字符, fgrep就是fixed grep或fast grep,它们把所有的字母都看作单词,也就是说,正则表达式中的元字符表示回其自身的字面意义,不再特殊。Linux使用GNU版本的grep。它功能更强,可以通过-G、-E、-F命令行选项来使用egrep和fgrep的功能。

  grep的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到屏幕,不影响原文件内容。

  grep可用于shell脚本,因为grep通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文件不存在,则返回2。我们利用这些返回值就可进行一些自动化的文本处理工作。

  grep --help

  匹配模式选择:

  -E, --extended-regexp 扩展正则表达式egrep

  -F, --fixed-strings 一个换行符分隔的字符串的集合fgrep

  -G, --basic-regexp 基本正则

  -P, --perl-regexp 调用的perl正则

  -e, --regexp=PATTERN 后面根正则模式,默认无

  -f, --file=FILE 从文件中获得匹配模式

  -i, --ignore-case 不区分大小写

  -w, --word-regexp 匹配整个单词

  -x, --line-regexp 匹配整行

  -z, --null-data 一个 0 字节的数据行,但不是空行

  杂项:

  -s, --no-messages 不显示错误信息

  -v, --invert-match 显示不匹配的行

  -V, --version 显示版本号

  --help 显示帮助信息

  --mmap use memory-mapped input if possible

  输入控制:

  -m, --max-count=NUM 匹配的最大数

  -b, --byte-offset 打印匹配行前面打印该行所在的块号码。

  -n, --line-number 显示的加上匹配所在的行号

  --line-buffered 刷新输出每一行

  -H, --with-filename 当搜索多个文件时,显示匹配文件名前缀

  -h, --no-filename 当搜索多个文件时,不显示匹配文件名前缀

  --label=LABEL print LABEL as filename for standard input

  -o, --only-matching 只显示一行中匹配PATTERN 的部分

  -q, --quiet, --silent 不显示任何东西

  --binary-files=TYPE 假定二进制文件的TYPE 类型;

  TYPE 可以是`binary', `text', 或`without-match'

  -a, --text 匹配二进制的东西

  -I 不匹配二进制的东西

  -d, --directories=ACTION 目录操作,读取,递归,跳过

  -D, --devices=ACTION 设置对设备,FIFO,管道的操作,读取,跳过

  -R, -r, --recursive 递归调用

  --include=PATTERN 只查找匹配FILE_PATTERN 的文件

  --exclude=PATTERN 跳过匹配FILE_PATTERN 的文件和目录

  --exclude-from=FILE 跳过所有除FILE 以外的文件

  -L, --files-without-match 匹配多个文件时,显示不匹配的文件名

  -l, --files-with-matches 匹配多个文件时,显示匹配的文件名

  -c, --count 显示匹配了多少次

  -Z, --null 在FILE 文件最后打印空字符

  文件控制:

  -B, --before-context=NUM 打印匹配本身以及前面的几个行由NUM控制

  -A, --after-context=NUM 打印匹配本身以及随后的几个行由NUM控制

  -C, --context=NUM 打印匹配本身以及随后,前面的几个行由NUM控制

  -NUM 根-C的用法一样的

  --color[=WHEN],

  --colour[=WHEN] 使用标志高亮匹配字串;

  -U, --binary 使用标志高亮匹配字串;

  -u, --unix-byte-offsets 当CR 字符不存在,报告字节偏移(MSDOS 模式)

  例:

  测试文件

  复制代码

  代码如下:

  root:x:0:0:root:/root:/bin/bash

  bin:x:1:1:bin:/bin:/bin/false,aaa,bbbb,cccc,aaaaaa

  DADddd:x:2:2:daemon:/sbin:/bin/false

  mail:x:8:12:mail:/var/spool/mail:/bin/false

  ftp:x:14:11:ftp:/home/ftp:/bin/false

  &nobody:$:99:99:nobody:/:/bin/false

  zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash

  http:x:33:33::/srv/http:/bin/false

  dbus:x:81:81:System message bus:/:/bin/false

  hal:x:82:82:HAL daemon:/:/bin/false

  mysql:x:89:89::/var/lib/mysql:/bin/false

  aaa:x:1001:1001::/home/aaa:/bin/bash

  ba:x:1002:1002::/home/zhangy:/bin/bash

  test:x:1003:1003::/home/test:/bin/bash

  @zhangying:*:1004:1004::/home/test:/bin/bash

  policykit:x:102:1005:Po

  a,匹配含有root的行

  复制代码

  代码如下:

  [root@krlcgcms01 test]# grep root test

  root:x:0:0:root:/root:/bin/bash

  b,匹配以root开头或者以zhang开头的行,注意反斜杠

  复制代码

  代码如下:

  [root@krlcgcms01 test]# cat test |grep '^\(root\|zhang\)'

  root:x:0:0:root:/root:/bin/bash

  zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash

  c,匹配以root开头或者以zhang开头的行,注意反斜杠,根上面一个例子一样,-e默认是省去的

  [root@krlcgcms01 test]# cat test |grep -e '^\(root\|zhang\)'

  root:x:0:0:root:/root:/bin/bash

  zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash

  d,匹配以zhang开头,只含有字母

  复制代码

  代码如下:

  [root@krlcgcms01 test]# echo 'zhangying' |grep '^zhang[a-z]*$'

  zhangying

  e,匹配以bin开头的行,用的egrep,在这里可以换成-F,-G

  复制代码

  代码如下:

  [root@krlcgcms01 test]# cat test |grep -E '^bin'

  bin:x:1:1:bin:/bin:/bin/false,aaa,bbbb,cccc,aaaaaa

  f,在匹配的行前面加上该行在文件中,或者输出中所在的行号

  复制代码

  代码如下:

  [root@krlcgcms01 test]# cat test|grep -n zhangy

  7:zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash

  13:ba:x:1002:1002::/home/zhangy:/bin/bash

  15:@zhangying:*:1004:1004::/home/test:/bin/bash

  g,不匹配以bin开头的行,并显示行号

  复制代码

  代码如下:

  [root@krlcgcms01 test]# cat test|grep -nv '^bin'

  root:x:0:0:root:/root:/bin/bash

  DADddd:x:2:2:daemon:/sbin:/bin/false

  mail:x:8:12:mail:/var/spool/mail:/bin/false

  ftp:x:14:11:ftp:/home/ftp:/bin/false

  &nobody:$:99:99:nobody:/:/bin/false

  zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash

  http:x:33:33::/srv/http:/bin/false

  dbus:x:81:81:System message bus:/:/bin/false

  hal:x:82:82:HAL daemon:/:/bin/false

  mysql:x:89:89::/var/lib/mysql:/bin/false

  aaa:x:1001:1001::/home/aaa:/bin/bash

  ba:x:1002:1002::/home/zhangy:/bin/bash

  test:x:1003:1003::/home/test:/bin/bash

  @zhangying:*:1004:1004::/home/test:/bin/bash

  policykit:x:102:1005:Po

  h,显示匹配的个数,不显示内容

  复制代码

  代码如下:

  [root@krlcgcms01 test]# cat test|grep -c zhang

  3

  i,匹配system,没有加-i没有匹配到东西。

  复制代码

  代码如下:

  [root@krlcgcms01 test]# grep system test

  [root@krlcgcms01 test]# grep -ni system test

  9:dbus:x:81:81:System message bus:/:/bin/false

  j,匹配zhan没有匹配到东西,匹配zhangy能匹配到,因为在test文件中,有zhangy这个单词

  复制代码

  代码如下:

  [root@krlcgcms01 test]# cat test|grep -w zhan

  [root@krlcgcms01 test]# cat test|grep -w zhangy

  zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash

  ba:x:1002:1002::/home/zhangy:/bin/bash

  k,在这里-x后面东西,和输出中的整行相同时,才会输出

  [root@krlcgcms01 test]# echo "aaaaaa" |grep -x aaa

  [root@krlcgcms01 test]# echo "aaaa" |grep -x aaaa

  aaaa

  l,最多只匹配一次,如果把-m 1去掉的话,会有三个

  复制代码

  代码如下:

  [root@krlcgcms01 test]# cat test |grep -m 1 zhang

  zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash

  m,匹配行的前面显示块号,这个块号是干什么的,不知道,有谁知道可否告诉我一下

  复制代码

  代码如下:

  [apacheuser@krlcgcms01 test]$ cat test |grep -b zha

  241:zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash

  480:ba:x:1002:1002::/home/zhangy:/bin/bash

  558:@zhangying:*:1004:1004::/home/test:/bin/bash

  n,多文件匹配时,在匹配的行前面加上文件名

  复制代码

  代码如下:

  [apacheuser@krlcgcms01 test]$ grep -H 'root' test test2 testbak

  test:root:x:0:0:root:/root:/bin/bash

  test2:root

  testbak:root:x:0:0:root:/root:/bin/bash

  o,多文件匹配时,在匹配的行前面不加上文件名

  复制代码

  代码如下:

  [apacheuser@krlcgcms01 test]$ grep -h 'root' test test2 testbak

  root:x:0:0:root:/root:/bin/bash

  root

  root:x:0:0:root:/root:/bin/bash

  p,多文件匹配时,显示匹配文件的文件名

  复制代码

  代码如下:

  [apacheuser@krlcgcms01 test]$ grep -l 'root' test test2 testbak DAta

  test

  test2

  testbak

  q,没有-o时,有一行匹配,这一行里面有3个root,加上-o后,这个3个root就出来了

  复制代码

  代码如下:

  [apacheuser@krlcgcms01 test]$ grep 'root' test

  root:x:0:0:root:/root:/bin/bash

  [apacheuser@krlcgcms01 test]$ grep -o 'root' test

  root

  root

  root

  r,递归显示匹配的内容,在test目录下面建个mytest目录,copy test目录下面的test文件到mytest下面,能看到上面的结果

  复制代码

  代码如下:

  [root@krlcgcms01 test]# grep test -R /tmp/test/mytest

  /tmp/test/mytest/test:test:x:1003:1003::/home/test:/bin/bash

  /tmp/test/mytest/test:@zhangying:*:1004:1004::/home/test:/bin/bash

  s,显示匹配root后面的3行

  复制代码

  代码如下:

  [root@krlcgcms01 test]# cat test |grep -A 3 root

  root:x:0:0:root:/root:/bin/bash

  bin:x:1:1:bin:/bin:/bin/false,aaa,bbbb,cccc,aaaaaa

  daemon:x:2:2:daemon:/sbin:/bin/false

  mail:x:8:12:mail:/var/spool/mail:/bin/false

  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。

  例:

  复制代码

  代码如下:

  [root@linux test]# cat abc.sh |fgrep a #匹配含有a的

看了“Linux文本匹配命令grep与fgrep使用全解”还想看:

1. linux grep命令详解

2. 全面解析Linux的grep命令中正则表达式的用法

3. Linux下如何使用grep命令搜索多个单词

4. 开发人员常用什么linux命令


如何在Linux下查找文件内容包含某个特定字符串的文件
(1)正则表达式一般用来描述文本模式的特殊用法,由普通字符(例如字符a-z)以及特殊字符(称为元字符,如\/、*、?等)组成。(2)基本元字符集及其含义 ^ :只匹配行首。 如^a 匹配以a开头的行abc,a2e,a12,aaa,...:只匹配行尾。 如^a 匹配以a结尾的行bca,12a,aaa,...:匹配0个或多个...

在linux中如何用命令查找文件在哪
1、find命令是linux中最强大的查找文件的命令,它的格式为”find <指定目录> <指定条件> <指定动作>“。比如使用find命令搜索在根目录下的所有interfaces文件所在位置,命令格式为”find \/ -name 'interfaces'”,输入后就会返回搜索的结果了:2、第二个命令是locate命令,使用locate也可以搜索到linux...

如何在Linux下查找文件内容包含某个特定字符串的文件
-n:只显示匹配行及其行号-s:不显示不存在或无匹配文本的错误信息。-v:显示不包含匹配文本的所有行。(2)举例说明:grep ^[^210] myfile 匹配myfile中以非2、1、0开头的行grep "[5-8][6-9][0-3]" myfile 匹配myfile中第一位为5|6|7|8,第二位6|7|8|9,第三位为0|1|2|3的三个字符的行grep...

linux查找目录下的所有文件中是否含有某个字符串
-l:查询多文件时只输出包含匹配字符的文件名 -n:只显示匹配行及其行号 -s:不显示不存在或无匹配文本的错误信息。 -v:显示不包含匹配文本的所有行。 (2)举例说明: grep ^[^210] myfile 匹配myfile中以非2、1、0开头的行 grep "[5-8][6-9][0-3]" myfile 匹配myfile中第一位为5|6|7|8,第二...

linux查找目录下的所有文件中是否含有某个字符串
-l:查询多文件时只输出包含匹配字符的文件名 -n:只显示匹配行及其行号 -s:不显示不存在或无匹配文本的错误信息。 -v:显示不包含匹配文本的所有行。 (2)举例说明: grep ^[^210] myfile 匹配myfile中以非2、1、0开头的行 grep "[5-8][6-9][0-3]" myfile 匹配myfile中第一位为5|6|7|8,第二...

linux查找目录下的所有文件中是否含有某个字符串
-l:查询多文件时只输出包含匹配字符的文件名 -n:只显示匹配行及其行号 -s:不显示不存在或无匹配文本的错误信息。 -v:显示不包含匹配文本的所有行。 (2)举例说明: grep ^[^210] myfile 匹配myfile中以非2、1、0开头的行 grep "[5-8][6-9][0-3]" myfile 匹配myfile中第一位为5|6|7|8,第二...

linux查找目录下的所有文件中是否含有某个字符串
-l:查询多文件时只输出包含匹配字符的文件名 -n:只显示匹配行及其行号 -s:不显示不存在或无匹配文本的错误信息。 -v:显示不包含匹配文本的所有行。 (2)举例说明: grep ^[^210] myfile 匹配myfile中以非2、1、0开头的行 grep "[5-8][6-9][0-3]" myfile 匹配myfile中第一位为5|6|7|8,第二...

linux查找目录下的所有文件中是否含有某个字符串
-l:查询多文件时只输出包含匹配字符的文件名 -n:只显示匹配行及其行号 -s:不显示不存在或无匹配文本的错误信息。 -v:显示不包含匹配文本的所有行。 (2)举例说明: grep ^[^210] myfile 匹配myfile中以非2、1、0开头的行 grep "[5-8][6-9][0-3]" myfile 匹配myfile中第一位为5|6|7|8,第二...

获嘉县15868228681: Linux下Grep命令的详细使用方法? -
征咱达乐: 在linux中grep命令是非常有用的,它和管道(|)配合使用,非常强大,用于搜索文本文件.如果想要在几个文本文件中查找一字符串,可以使用'grep'命令.'grep'在文本中搜索指定的字符串. 假设您正在'/usr/src/linux/Documentation'目...

获嘉县15868228681: linux的grep查询命令 -
征咱达乐: grep默认只能识别基本的正则表达式,如果需要高级的,需要这样:grep -E 'A.*B|B.*A' filename 可以找到符合要求的,或者使用awk:awk '/A/&&/B/' filename

获嘉县15868228681: linux grep命令怎么用 -
征咱达乐: grep (global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来. Unix的grep家族包括grep、egrep和fgrep.egrep和...

获嘉县15868228681: find和grep都是查找,他们的区别是什么? -
征咱达乐: find命令和grep命令虽然都是查找,但是区别是很大的.一定要搞清楚.具体而言就是 1.find命令是指查找特定路径下指定文件(包括子目录),类似于我们window下的win+f键 . 2,grep命令是在一个文件的文本中查找字符 .类似于与文件里面ctrl+f. 测试人员学习Linux,可以为自己的生涯添一笔重彩,你可以到黑马程序员看Linux的学习视频,不会让你失望的.

获嘉县15868228681: linux grep是什么? -
征咱达乐: Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来.grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户.

获嘉县15868228681: linux系统grep命令有什么用 -
征咱达乐: 这个命令全程global regular print是通过正则表达式打印出匹配的字符串或者文件行.

获嘉县15868228681: linux中grep和find的区别 -
征咱达乐: 这是两个不同的命令,关于grep:Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来.grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户....

获嘉县15868228681: ps - ef | grep 怎么使用? -
征咱达乐: PS是LINUX下最常用的也是非常强大的进程查看命令 //以下这条命令是检查java 进程是否存在. ps -ef |grep java下面对命令选项进行说明: -e 显示所有进程. -f 全格式.ps e 列出程序时,显示每个程序所使用的环境变量. ps f 用ASCII字符显示树状结构,表达程序间的相互关系grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来.grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户. ps -ef | grep httpd : 检查httpd进程是否存在

获嘉县15868228681: grep "flags" /proc/cpuinfo |uniq 命令如何一步一步详细解释 -
征咱达乐: ps 在linux中是报各程序状况,-e,-f,合起来-ef其中,-e表示显示所有程序;-f表示显示UID,PPIP,C与STIME栏位."|"表示管道"grep"管道命令,"^"表示以XX打头.在正则表达式中,* 表示匹配前面一个字符的零次或多个出现,$ 表示匹配...

获嘉县15868228681: 什么过滤操作?在Linux中如何实现? -
征咱达乐: 过滤操作就是指在一大堆文本信息中筛选出你关心的数据. 一般用 ls + 通配符,或 grep, sed 或 awk 这些支持正则表达式的工具都可以实现过滤操作. 比如: ls *.jpg #过滤出当前目录下以jpg为后缀的所有文件,这是通配符用法 grep "abc" file.txt #过滤出file.txt中包含abc的行,这里没有使用正则表达式 ls | grep "[a-z][0-9].csv" #从ls的结果中过滤出文件名格式为一个字母加一位数字并以.csv为后缀的文件名,这里用了正则表达式(字母集合[a-z]与数字集合[0-9])

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网