学习啦>学习电脑>操作系统>Linux教程>

linux文本内容操作系列grep命令详解

志艺分享

  Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。接下来是小编为大家收集的linux文本内容操作系列grep命令详解,欢迎大家阅读:

  linux文本内容操作系列grep命令详解

  grep

  这算是文本内容的一个重量级选手,能根据某些规格在上千行的文本文件中查找所需要的数据。他能接受正则表达式和通配符。

  础实例:

  1. 命令翻译包含给定match_pattern的文本行,如我在grep.txt中查找PATTERN

  grep PATTERN grep.txt

  or grep "PATTERN" grep.txt

  2. 匹配多个文件

  grep PATTERN grep.txt grep1.txt

  3. 从stdin中读取

  echo –e "this is a word\nnext line" | grep word

  打印:this is a word

  4. grep 与 正则表达式

  grep –E "[a-z]+"

  或者

  egrep "[a-z]+"

  5. 只输出匹配部分,而不是匹配的当前行

  echo this is line. | greip –o –E "[a-z]+\."

  输出:line

  6. 打印除包含match_pattern的行之外的所有行,可使用

  grep -v match_pattern file

  7. 统计文本或者文件中包含匹配字符串的字数(这个面试经常会问到)

  $grep -c "text" filename

  但他给出的是匹配行的次数,而不是匹配的次数

  统计匹配数量的话,可以用到下面的技巧

  $echo –e "1 2 3 4\nhello\n5 6"| egrep -o "[0-9]" | wc –l

  打印1到6 | 从stdin中读取数字,分行打印 | 统计行数

  8. 打印行号

  grep "text" -n filename

  9. 搜2个文件,以及他们的行号,输出会打印文件名

  grep "text"–n s1.txt s2.txt

  10.如果你只想知道哪些文件有 单词PATTERN

  grep –l PATTER s1.txt s2.txt

  -L则返回的不匹配文件列表

  11.可以再整个目录下查找 单词PATTERN 在那些文件里

  grep PATTERN . -R -n

  12 同时多个匹配查找

  echo this is a line of text | grep -e "this" -e "line" -o

  打印:

  this

  line

  13 只在某些合适的文件中搜索

  grep "main()" .-r --include *.{c,cpp}

  只在.c 和.cpp结尾的文件中搜索 main()

  14 进行搜索排除某些文件

  grep "main()" . -r --exclude "README"

  排除了所有文件名为"README"的文件

  15 打印匹配之前或之后的3行

  seq 10 | grep 5 –A 3 之前

  seq 10 | grep 6 –B 3 之后

  16 打印匹配前后3行,同时输出

  seq 10 | grep 5 –C 3

  我们来看下--help

  复制代码代码如下:

 

  
看了“linux文本内容操作系列grep命令详解”还想看:

1.Linux系统中怎么使用grep命令

2.15个Linux Grep命令使用实例

3.Linux中常用操作命令总结

4.Linux常用操作命令汇总

    2991469