1、简介

    grep 是个很强大的命令,用来找到文件中的匹配文本,并且能够接受正则表达式和通配符,同时可以用多个 grep 命令选项来生成各种格式的输出
    

1.1 搜索/过滤

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

1.2 返回值

    grep 可用于 shell 脚本,因为 grep 通过返回一个状态值来说明搜索的状态
        模板搜索成功,则返回 0
        搜索不成功,则返回 1
        搜索的文件不存在,则返回 2
    

2、用法/命令格式

    grep [OPTIONS] PATTERN [FILE...]
    grep [OPTIONS] [-e PATTERN]...  [-f FILE]...  [FILE...]

    

3、常用选项

选项 描述
-c 计算找到 '搜寻字符串'的次数
-i 忽略大小写的不同
-n 输出行号
-v 反向选择,打印不匹配的行
-r 递归搜索
--color=auto 将找到的关键词部分加上颜色显示

    

4、范例

4.1 过滤 单一文件

# grep "root" /etc/passwd --color=auto
# cat /etc/passwd | grep "root" --color=auto

    

4.2 过滤 文件夹

# grep -R "root" /etc/* --color=auto

    

5、扩展 -- 正则表达式与 grep 命令

正则表达式是一种符号表示法,被用来识别文本模式;正则表达式元字符由以下字符组成:^ $ . [ ] { } - ? * + ( ) | \
正表达式 描述
^ 行 起始 符
$ 行尾 符
. 匹配 任意 一个 字符
[] 匹配 [字符] 之中 任意 一个 字符
[字符1-字符2] 匹配 字符1 - 字符2 之间 任意 一个 字符;例如 A - G
{n} 匹配 之前的项 n 次
{n,} 匹配 之前的项 至少 n次
{min,max} 匹配最小/大 值(极值)
? 匹配 0 或 1 个 次
* 匹配 任意 次
+ 匹配 一次 或 多次

    

5.1 匹配 空格(任意)

# grep "^[ \s]\{1,\}" {file_name}

    

5.2 模糊匹配

## 查找一个五个字母的单词,第三个字母为 j,最后一个字母为 r 内容
# grep '^..j.r$' {file}

    

5.3 电话 号码 匹配

## 固定电话格式基本都是带有 0 的区号+连接符“-”+电话号码,另外还有可能有分机号,区号有 3 位、4 位,电话号码有 7 位和 8 位的
## 区号:前面一个 0,后面跟 2-3 位数字 : 0[0-9]{2,3}
## 电话号码:7-8 位数字: [0-9]{7,8}
## 分机号:一般都是 3-4 位数字: [0-9]{3,4} 
## -E 选项,grep 会识别 正则表达式的元字符
# grep -E "^0[0-9]{2,3}-[0-9]{7,8}(-[0-9]{3,4})?$" {telphone.txt}