转自:https://www.aliyun.com/jiaocheng/1390860.html?spm=5176.100033.1.9.6a1e41e8Pdjynm

    • 摘要:Grep命令主要用于从文件中查找指定的字符串。首先建一个demo_file:$catdemo_fileTHISLINEISTHE1STUPPERCASELINEINTHISFILE.thislineisthe1stlowercaselineinthisfile.ThisLineHasAllItsFirstCharacterOfTheWordWithUpperCase.Twolinesabovethislineisempty.Andthisisthelastline.例01:从
    • Grep命令主要用于从文件中查找指定的字符串。

      首先建一个demo_file:

      $ cat demo_file
      THIS LINE IS THE 1ST UPPER CASE LINE IN THIS FILE.
      this line is the 1st lower case line in this file.
      This Line Has All Its First Character Of The Word With Upper Case. Two lines above this line is empty.
      And this is the last line.

      例01:从单个文件中查找指定的字符串

      $ grep "this" demo_file
      this line is the 1st lower case line in this file.
      Two lines above this line is empty.

      例02:从多个文件中查找指定的字符串

      $ cp demo_file demo_file1
      
      $ grep "this" demo_*
      demo_file:this line is the 1st lower case line in this file.
      demo_file:Two lines above this line is empty.
      demo_file:And this is the last line.
      demo_file1:this line is the 1st lower case line in this file.
      demo_file1:Two lines above this line is empty.
      demo_file1:And this is the last line.

      例03:忽略大小写使用 grep -i

      $ grep -i "the" demo_file
      THIS LINE IS THE 1ST UPPER CASE LINE IN THIS FILE.
      this line is the 1st lower case line in this file.
      This Line Has All Its First Character Of The Word With Upper Case.
      And this is the last line.

      例04:在文件中匹配正则表达式

      如果你能在实际使用正则表达式,能使效率大大提高。在下面的例子中,匹配了所有以lines开头,以empty结尾的行。

      $ grep "lines.*empty" demo_file
      Two lines above this line is empty.

      从Grep文档的来看,一个正则表达式必须遵循下面的匹配操作。

      • ?         The preceding item is optional and matched at most once.
      • *          The preceding item will be matched zero or more times.
      • +         The preceding item will be matched one or more times.
      • {n}      The preceding item is matched exactly n times.
      • {n,}     The preceding item is matched n or more times.
      • {,m}    The preceding item is matched at most m times.
      • {n,m}  The preceding item is matched at least n times, but not more than m times.

      例05:用grep -w来查找全匹配,不包括子字符串

      比如说:用下面的例子搜索出来的例子包括"is","his"

      $ grep -i "is" demo_file
      THIS LINE IS THE 1ST UPPER CASE LINE IN THIS FILE.
      this line is the 1st lower case line in this file.
      This Line Has All Its First Character Of The Word With Upper Case.
      Two lines above this line is empty.
      And this is the last line.

      而用grep -iw搜索出来的结果如下: 注意,忽略大小。"IS","is"

      $ grep -iw "is" demo_file
      THIS LINE IS THE 1ST UPPER CASE LINE IN THIS FILE.
      this line is the 1st lower case line in this file.
      Two lines above this line is empty.
      And this is the last line.

      例06:用grep -A,-B,-C 来查看after/before/around 行

      当在一个大的文件中执行grep操作时,如果想要看其中一些行,并且想看之前,之后的或某些行附近的,那么这里命令就起作用了。grep -A,-B,-C.先建个demo.txt作为模板

      $ cat demo_text
      4. Vim Word Navigation You may want to do several navigation in relation to the words, such as: * e - go to the end of the current word.
      * E - go to the end of the current WORD.
      * b - go to the previous (before) word.
      * B - go to the previous (before) WORD.
      * w - go to the next word.
      * W - go to the next WORD. WORD - WORD consists of a sequence of non-blank characters, separated with white space.
      word - word consists of a sequence of letters, digits and underscores. Example to show the difference between WORD and word * 192.168.1.1 - single WORD
      * 192.168.1.1 - seven words.

      6.1 显示匹配后N行

      $ grep -A 3 -i "example" demo_text
      Example to show the difference between WORD and word * 192.168.1.1 - single WORD
      * 192.168.1.1 - seven words.

      6.2 显示匹配前N行

      $ grep -B 2 "single WORD" demo_text
      Example to show the difference between WORD and word * 192.168.1.1 - single WORD

      6.3 显示匹配前N行

      $ grep -C 2 "Example" demo_text
      word - word consists of a sequence of letters, digits and underscores. Example to show the difference between WORD and word * 192.168.1.1 - single WORD

      例07:用GREP_OPTIONS来让查找的项醒目

      如果你想使匹配的好看且醒目,可以使用下面的操作:

      $ export GREP_OPTIONS='--color=auto' GREP_COLOR='100;8'
      
      $ grep this demo_file
      this line is the 1st lower case line in this file.
      Two lines above this line is empty.
      And this is the last line.

      例08:用grep -r来搜索所有的文件及子目录

      $ grep -r "ramesh" *

      例09:用grep -v来显示不匹配的项

      $ grep -v "go" demo_text
      4. Vim Word Navigation You may want to do several navigation in relation to the words, such as: WORD - WORD consists of a sequence of non-blank characters, separated with white space.
      word - word consists of a sequence of letters, digits and underscores. Example to show the difference between WORD and word * 192.168.1.1 - single WORD
      * 192.168.1.1 - seven words.

      例10:显示所有不匹配的项

      $ cat test-file.txt
      a
      b
      c
      d $ grep -v -e "a" -e "b" -e "c" test-file.txt
      d

      例11:用grep -c 来计算匹配的数量

      11.1计算匹配的字符串数

      $ grep -c "go" demo_text
      6

      11.2计算匹配的模式数

      $ grep -c this demo_file
      3

      11.3计算不匹配的模式数

      $ grep -v -c this demo_file
      4

      例12:使用grep -l显示匹配的文件名

      $ grep -l this demo_*
      demo_file
      demo_file1

      例13:只显示匹配的字符串

      $ grep -o "is.*line" demo_file
      is line is the 1st lower case line
      is line
      is is the last line

      例14:

      $ cat temp-file.txt1234512345
      $ grep -o -b "3" temp-file.txt
      2:3
      8:3

      注意:上述的不是该字符所在行中的位置,而是字节的位置。

      例15:用grep -n 显示行数

      $ grep -n "go" demo_text
      5: * e - go to the end of the current word.
      6: * E - go to the end of the current WORD.
      7: * b - go to the previous (before) word.
      8: * B - go to the previous (before) WORD.
      9: * w - go to the next word.
      10: * W - go to the next WORD.

      原文链接: http://www.thegeekstuff.com/2009/03/15-practical-unix-grep-command-examples/

    • 以上是

Linux中Grep常用的15个例子

      的内容,更多 的内容,请您使用右上方搜索功能获取相关信息。

Linux中Grep常用的15个例子【转】的更多相关文章

  1. Linux中许多常用命令是必须掌握的,这里将我学linux入门时学的一些常用的基本命令分享给大家一下,希望可以帮助你们。

    Linux中许多常用命令是必须掌握的,这里将我学linux入门时学的一些常用的基本命令分享给大家一下,希望可以帮助你们. 这个是我将鸟哥书上的进行了一下整理的,希望不要涉及到版权问题. 1.显示日期的 ...

  2. Linux中grep和egrep命令详解

    rep / egrep 语法: grep  [-cinvABC]  'word'  filename -c :打印符合要求的行数-i :忽略大小写-n :在输出符合要求的行的同时连同行号一起输出-v ...

  3. linux中的常用命令

    cat tail -f 日 志 文 件 说 明 /var/log/message 系统启动后的信息和错误日志,是Red Hat Linux中最常用的日志之一 /var/log/secure 与安全相关 ...

  4. linux中grep命令的用法

    作为linux中最为常用的三大文本(awk,sed,grep)处理工具之一,掌握好其用法是很有必要的. 首先谈一下grep命令的常用格式为:[grep  [选项]  "模式"  [ ...

  5. 12个 Linux 中 grep 命令的超级用法实例

    12个 Linux 中 grep 命令的超级用法实例 你是否遇到过需要在文件中查找一个特定的字符串或者样式,但是不知道从哪儿开始?那么,就请grep来帮你吧. grep是每个Linux发行版都预装的一 ...

  6. linux中grep命令的使用

    转载:http://blog.csdn.net/universsky/article/details/8866402 linux中grep命令的使用 grep (global search regul ...

  7. linux中的常用信号

    linux中的常用信号,见如下列表: 信号名 值 标注 解释 ------------------------------------------------------------------ HU ...

  8. Linux中grep命令的12个实践例子

    grep是每个Linux发行版都预装的一个强有力的文件模式搜索工具.无论何种原因,如果你的系统没有预装它的话,你可以很容易的通过系统的包管理器来安装它(Debian/Ubuntu系中的apt-get和 ...

  9. Linux 中 grep 命令的 12 个实践例子

    2017-10-17 Linux小管家 你是否遇到过需要在文件中查找一个特定的字符串或者样式,但是不知道从哪儿开始?那么,就请grep来帮你吧. grep是每个Linux发行版都预装的一个强有力的文件 ...

随机推荐

  1. ps -ef | grep Linux进程查看命令

    我们常常会想查看Linux的一些进程,很自然地用到了: ps -ef | grep xxx ps: process show 展示进程 参数:1. e 显示所有程序. 2. f  显示UID,PPIP ...

  2. 转 G1垃圾收集器入门

    转自:http://blog.csdn.net/zhanggang807/article/details/45956325 最近在复习Java GC,因为G1比较新,JDK1.7才正式引入,比较艰难的 ...

  3. golang channle 管道

    管道的使用介绍 现在要计算 1-N 的各个数的阶乘,并且把各个数的阶乘放入到 map 中.最后显示出来.要求使用 goroutine 完成 package main import ( "fm ...

  4. ZooKeeper基础

    ======================================ZooKeeper 背景======================================ZooKeeper 是一 ...

  5. linux centos 7 nodejs 的安装

    先SSH 进到终端 随便一目录,或者/temp下 下载nodejs: (如果下载不了,官网 https://nodejs.org/en/download/复制LINUX版本的链接过来) wget ht ...

  6. JDK8新特性03 Lambda表达式03_Java8 内置的四大核心函数式接口

    import java.util.ArrayList; import java.util.Arrays; import java.util.List; import java.util.functio ...

  7. 【核心】project(idea文件)、module(iml文件)到SSM集成、热部署、Tomcat启动、MAVEN依赖冲突

    http://wiki.jikexueyuan.com/project/intellij-idea-tutorial/project-composition-introduce.html 在 Inte ...

  8. 深度优先遍历(DFS)(转)

    优先搜索(DFS, Depth First Search)是一个针对图和树的遍历算法.早在19世纪就被用于解决迷宫问题. 对于下面的树而言,DFS方法首先从根节点1开始,其搜索节点顺序是1,2,3,4 ...

  9. Frameset 框架

      <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="index.aspx.c ...

  10. Codeforces Round #516 (Div. 2, by Moscow Team Olympiad)

    题目链接 A. Make a triangle! 题意 让某段最少增加多少使得构成三角形 思路 让较小两段往最长段去凑 代码 #include <bits/stdc++.h> #defin ...