zoukankan      html  css  js  c++  java
  • linux grep --我最喜欢的命令~~

    转:http://www.cnblogs.com/end/archive/2012/02/21/2360965.html

    Grep 命令 用法大全

    1、 参数: 
    -I :忽略大小写 
    -c :打印匹配的行数 
    -l :从多个文件中查找包含匹配项 
    -v :查找不包含匹配项的行 
    -n:打印包含匹配项的行和行标 

    2、RE(正则表达式) 
    忽略正则表达式中特殊字符的原有含义 
    ^ 匹配正则表达式的开始行 
    $ 匹配正则表达式的结束行 
    < 从匹配正则表达式的行开始 
    > 到匹配正则表达式的行结束 
    [ ] 单个字符;如[A] 即A符合要求 
    [ - ] 范围 ;如[A-Z]即A,B,C一直到Z都符合要求 
    . 所有的单个字符 
    * 所有字符,长度可以为0 


    基本格式
    grep pattern [file...]
    (1)grep 搜索字符串 [filename]
    (2)grep 正则表达式 [filename]
    在文件中搜索所有 pattern 出现的位置, pattern 既可以是要搜索的字符串,也可以是一个正则表达式.
    注意:在输入要搜索的字符串时最好使用双引号/而在模式匹配使用正则表达式时,注意使用单引号

    2,grep的选项
        -c 只输出匹配行的计数
        -i 不区分大小写(用于单字符)
        -n 显示匹配的行号
        -v 不显示不包含匹配文本的所以有行
        -s 不显示错误信息
        -E 使用扩展正则表达式
        更多的选项请查看:man grep

    3,常用grep实例

    (1)多个文件查询
        grep "sort" *.doc       #见文件名的匹配

    (2)行匹配:输出匹配行的计数
        grep -c "48" data.doc   #输出文档中含有48字符的行数

    (3)显示匹配行和行数
        grep -n "48" data.doc       #显示所有匹配48的行和行号

    (4)显示非匹配的行
        grep -vn "48" data.doc      #输出所有不包含48的行

    (4)显示非匹配的行
        grep -vn "48" data.doc      #输出所有不包含48的行

    (5)大小写敏感
        grep -i "ab" data.doc       #输出所有含有ab或Ab的字符串的行

    4, 正则表达式的应用

    (1)正则表达式的应用 (注意:最好把正则表达式用单引号括起来)
        grep '[239].' data.doc      #输出所有含有以2,3或9开头的,并且是两个数字的行

    (2)不匹配测试
        grep '^[^48]' data.doc      #不匹配行首是48的行

    (3)使用扩展模式匹配
        grep -E '219|216' data.doc

    (4) ...
        这需要在实践中不断应用和总结,熟练掌握正则表达式。

    5, 使用类名
    可以使用国际模式匹配的类名:
    [[:upper:]]   [A-Z]
    [[:lower:]]   [a-z]
    [[:digit:]]   [0-9]
    [[:alnum:]]   [0-9a-zA-Z]
    [[:space:]]   空格或tab
    [[:alpha:]]   [a-zA-Z]

    (1)使用
        grep '5[[:upper:]][[:upper:]]' data.doc     #查询以5开头以两个大写字母结尾的行

    举例:

    # grep 'the' size.txt 
    the test file 
    their are files 

    # grep '<the' size.txt 
    the test file 
    their are files 

    # grep 'the>' size.txt 
    the test file 

    # grep '<the>' size.txt 
    the test file 

    # grep '<[Tt]he>' size.txt 
    the test file


    自己的实践: 

    显示行内容和行号:

    $ grep -n "^夺宝" 1.word    
    16:夺宝记
    1219:夺宝计上计
    2220:夺宝
    4000:夺宝幸运星

    在当前文件夹显示已.log结尾的所有文件:

    $ grep -L *.log   
    10.log
    11.log
    12.log
    22.log
    23.log
    24.log
    2.log
    3.log

  • 相关阅读:
    合并n个链表
    合并2个链表
    删除链表中的倒数第n个元素
    判断字符串是否回文字符串
    回文链表
    反转链表
    反转链表2
    冒泡排序法
    编译datax(3.x版本)踩的坑,记录修改记录
    Python基本知识(6)——集合
  • 原文地址:https://www.cnblogs.com/lifegoesonitself/p/3513504.html
Copyright © 2011-2022 走看看