当前位置: > Linux命令 >

linux命令:grep,sort,find,uniq用法详解

时间:2015-05-02 00:45来源:linux.it.net.cn 作者:IT
四个重要的linux命令,grep命令、sort命令、find命令与uniq命令的用法,这几个linux命令的格式、选项与用法例子。


四个常用的linux命令:

1、grep命令
全面搜索正则表达式并把行打印出来,是一种强大的文本搜索工具,它使用正则表达式搜索文本,并把匹配的行打印出来。
grep(全局正则表达式版本)允许对文本文件进行模式查找。如果找到匹配模式,grep打印包含模式的所有行。grep支持基本正则表达式,也支持其扩展集。
资料:man grep
功能:
使用正则表达式搜索文本并打印匹配行

格式:
grep [options] PATTERN [Files]
注:输入字符串作为参数,最好双引号括起  “mystr”[ 一以防被误解为shell命令,二可以用来查找多个单词组成的字符串]
在调用变量时,也使用双引号括起  “$MYSTR”
使用正则[匹配模式]是,应使用单引号括起  ‘49[32]’

选项
-c
只输出匹配的行数,而不输出匹配的行
-i
不区分大小写
-h
查询多个文件时不显示文件名【默认是 文件名:符合的记录行】
-l
查询多个文件时,只输出包含匹配字符的文件名
-n
显示匹配行及行号
-s
不显示不存在或无匹配文本的错误信息
-v
显示不包含匹配文本的所有行
-o
仅显示匹配的部分
-r
递归选项。指示GNUgrep和egrep检查做为参数的目录下的文件,然后递归的检查该目录下所有子目录下的文件
-E
启用扩展表达式,可使用扩展元字符 egrep
 +
  匹配一个或多个先前的字符。如:'[a-z]+able',匹配一个或多个小写字母后跟able的串,如loveable,enable,disable等。
 ?
匹配零个或1个先前的字符。如:'gr?p'匹配gr后跟一个或没有字符,然后是p的行。
  *
    匹配0个或多个
 a|b|c
  匹配a或b或c。如:grep|sed匹配grep或sed
 ()
  分组符号,如:love(able|rs)ov+匹配loveable或lovers,匹配一个或多个ov。
 x,x{m,},x{m,n}
作用同x\{m\},x\{m,\},x\{m,n\}
  {n}必须匹配n次   {n,}至少匹配n次  {n,m}匹配次数在[n,m]之间

 

例子:
1、查询多个文件
 

grep “sort” *.doc    在目录下所有doc文件中查sort
grep “sort” filea fileb  在filea,fileb中查找

2、计算匹配行数
 

grep –c “test” data.txt

3、显示非匹配行
 

grep –v “test” data.txt

4、忽略大小写
默认是大小写敏感的,若需要,使用-i进行忽略
 

grep –i “ignore” data.txt

5、正则表示
 

grep ‘48[34]’ data.txt
grep ‘^[^48]’ data.txt 开头不是4,8的
grep ‘[Ss]ept’ data.txt
grep ‘^[0-9][0-5][0-6]’
grep ‘4\{2,\}’ data

6、使用“与” “或”
必须使用参数 –E [E一定大写]
 

grep –E ‘aaa|bbb’ data
等价于 grep –c “[L|l]et” dream

7、空行及特殊字符
 

grep ‘^$’ data
grep ‘\.’ myfile

8、类名:
 

grep 允许使用国际字符串模式匹配或匹配模式的类名
[[:upper:]]
[A-Z]
[[:lower:]]
[a-z]
[[:digit:]]
[0-9]
[[:alnum:]]
[0-9a-zA-Z]
[[:space:]]

空格或tab键
[[:alpha:]]
[a-zA-Z]
grep ‘5[[:upper:]] [[:upper:]]’ data  5开头,两个大写

9、系统grep命令
 

ls –l | grep ‘^d’
ls –l | grep ‘^[^d]’

查找内容前后的多少行
 

-A NUM, --after-context=NUM   匹配行之后多少行[ahead]
-B NUM, --before-context=NUM  匹配行之前多少行[back]
-C NUM,--context=NU、匹配行前后多少行[上下文context]

处理二进制文件
Grep查找的是text文件,
如果要查找的是二进制文件,则输出如下结果:Binary file file-name matches
-a, --text  使用-a进行二进制文件处理,结果类似文本文件
点亮匹配的内容
将匹配上的内容加颜色显示出来
--colour[=WHEN], --color[=WHEN]   三种WHEN=never,always,auto
匹配内容的统计与其他
将匹配的内容进行记录统计
-c, --count   -c,统计匹配行数, -cv统计不匹配行数
-o, --only-matching(只显示匹配的内容)
查看目录下面的所有文件(包括子目录)
-R, -r, --recursive   递归,查询所有子目录
--include=PATTERN  只查询该模式文件
--exclude=PATTERN  不查询该模式文件
-n, --line-number   输出文件名及匹配行号
如何匹配以“-”开始的字符
-e PATTERN, --regexp=PATTERN   使用正则
在哪些文件中出现
-h, --no-filename  结果中不输出文件名
-L, --files-without-match 输出没有匹配上的文件名列表
反向匹配
-v, --invert-match  反向,未匹配的行
-m NUM, --max-count=NUM 最大匹配次数


(责任编辑:IT)

------分隔线----------------------------
栏目列表
推荐内容