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

Linux命令学习 -- grep命令

程序员文章站 2024-02-23 23:34:42
...

文章目录


命令格式grep [OPTION]... PATTERN [FILE]...

解释:在每个 FILE 或标准输入中搜索 PATTERN。
默认情况下,PATTERN 是一个基本的正则表达式 (BRE)。

示例:grep -i ‘hello world’ menu.h main.c

常用参数 (grep --help)

# 正则表达式选择和解释:
  -E, --extended-regexp PATTERN 是扩展正则表达式 (ERE)
  -e, --regexp=PATTERN 使用 PATTERN 进行匹配
  -f, --file=FILE 从 FILE 获取 PATTERN
  -i, --ignore-case 忽略大小写区别
  -w, --word-regexp 强制 PATTERN 只匹配整个单词
  -x, --line-regexp 强制 PATTERN 只匹配整行
  -v, --invert-match 选择不匹配的行

# 输出控制:
  -m, --max-count=NUM 最多匹配 NUM 个后停止
  -n, --line-number 用输出行打印行号
      --line-buffered 每一行的刷新输出
  -H, --with-filename 打印每个匹配的文件名
  -h, --no-filename 禁止输出文件名前缀
      --label=LABEL 使用 LABEL 作为标准输入文件名前缀
  -o, --only-matching 只显示匹配 PATTERN 的行的一部分
  -q, --quiet, --silent 抑制所有正常输出
      --binary-files=TYPE 假设二进制文件是 TYPE;
                            TYPE 是 binary 、 text 或 without-match
  -a, --text 等同于 --binary-files=text
  -L, --files-without-match 只打印不包含匹配项的文件名
  -l, --files-with-matches 只打印包含匹配项的文件名
  -c, --count 只打印每个文件的匹配行数
  -T, --initial-tab 使标签对齐(如果需要)

# 上下文控制:
  -B, --before-context=NUM 打印匹配内容的前 NUM 行
  -A, --after-context=NUM 打印匹配内容的后 NUM 行
  -C, --context=NUM 打印匹配内容的前后 NUM 行

用法实例

# 查找文件内容(这样也可以:cat file.txt| grep 768)
[[email protected] ~]# grep 768 file.txt
1.0.1.0	1.0.3.255	768
1.2.0.0	1.2.2.255	768
1.2.0.0	1.2.2.255	768

# 忽略大小写
[[email protected] ~]# grep Aa file.txt
Aabcd
[[email protected] ~]# grep -i Aa file.txt
Aabcd
AABCD

# 打印行号(-i和-n可以合并写成 -in )
[[email protected] ~]# grep -in Aa file.txt
23:Aabcd
24:AABCD

# 多文件搜索+打印文件名(多文件默认输出文件名,使用-h可以取消输出)
[[email protected] ~]# grep -H Aabcd file*
file2.txt:Aabcd i am file2
file.txt:Aabcd

# 使用file2.txt的输出作为 pattern ,匹配file.txt的内容
# 输出为file.txt 和 file2.txt 相同的内容
[[email protected] ~]# grep -f file2.txt file.txt
1.1.2.0	1.1.63.255	15872
1.1.2.0	1.1.63.255	15872

LeetCode实战

给定一个文本文件 file.txt,请只打印这个文件中的第3行。
示例:

假设 file.txt 有如下内容:
Line 1
Line 2
Line 3

你的脚本应当显示第3行:
Line 3

贴一个LeetCode上大佬的解法(不是最优解,不过对grep运用很巧妙)

grep 一般都是使用匹配找行信息,不建议在这里使用

grep '' -n file.txt | grep '^10:' | cut -d ':' -f 2

原理:
grep '' -n 给每行加上行号
grep 匹配行号‘10:’
cut':'字符作为分割 划分fileds 输出第二个filed(从1开始算)
问题: 如果正文出现‘:’字符 会出错