this is a words file.
words words to be
, , , , , , , , , ,
beginning linux programming 4th edition this is a line containing pattern
,.<>?;';;;' [] {= = \ \ \| -__!@#$%^&*() !@#$$%%^&*(()*&%@(#$%)) www.regexper.com
www.google.com
www.baidu.com
www.redhat.com

我们的测试文件名字叫 n,如上所示,共13行。

grep按行检索,按行输出。

1, 搜索特定模式的行

 [lizhen@dhcp-- shell]$ grep words n
this is a words file.
words words to be
[lizhen@dhcp-- shell]$

2,单个grep命令可以对多个文件进行检索

[lizhen@dhcp-- shell]$ grep words n n1 n2
n:this is a words file.
n:words words to be
n1:this is a words file.
n1:words words to be
n2:this is a words file.
n2:words words to be
[lizhen@dhcp-- shell]$

3,使用正则表达式,添加-E选项,或者直接egrep   (在terminal下可以看到这些被匹配的部分 是被红色 特殊显示的,这里显示的是被匹配到的 行)

[lizhen@dhcp-- shell]$ egrep "[a-o]+" n
this is a words file.
words words to be
beginning linux programming 4th edition
this is a line containing pattern
www.regexper.com
www.google.com
www.baidu.com
www.redhat.com
[lizhen@dhcp-- shell]$

4,只输出文件中匹配到的文本部分呢,使用-o

[lizhen@dhcp-- shell]$ grep words n
this is a words file.
words words to be
[lizhen@dhcp-- shell]$ grep words n -o
words
words
words
[lizhen@dhcp-- shell]$

5,打印除包含match_pattern行之外的所有行,使用-v

[lizhen@dhcp-- shell]$ grep words n -v
, , , , , , , , , ,
beginning linux programming 4th edition this is a line containing pattern
,.<>?;';;;' [] {= = \ \ \| -__!@#$%^&*() !@#$$%%^&*(()*&%@(#$%)) www.regexper.com
www.google.com
www.baidu.com
www.redhat.com
[lizhen@dhcp-- shell]$

6,统计文件包含匹配字符串的行数,使用-c   (-c只统计匹配到的行数,并不会统计匹配到的次数)

[lizhen@dhcp-- shell]$ grep words n -c

[lizhen@dhcp-- shell]$ grep words n
this is a words file.
words words to be
[lizhen@dhcp-- shell]$

7,统计匹配到的字符串的数量,使用-o    |    wc -l

[lizhen@dhcp-- shell]$ grep -o words n | wc -l

[lizhen@dhcp-- shell]$ grep words n
this is a words file.
words words to be
[lizhen@dhcp-- shell]$

8,打印出包含匹配字符串的行号,使用-n

[lizhen@dhcp-128-93 shell]$ grep w -n n n1
n:1:this is a words file.
n:2:words words to be
n:10:www.regexper.com
n:11:www.google.com
n:12:www.baidu.com
n:13:www.redhat.com
n1:1:this is a words file.
n1:2:words words to be
n1:10:www.regexper.com
n1:11:www.google.com
n1:12:www.baidu.com
n1:13:www.redhat.com
[lizhen@dhcp-128-93 shell]$

9 打印模式匹配所位于的字符或字节偏移,使用-b  -o

[lizhen@dhcp-- shell]$ grep words n
this is a words file.
words words to be
[lizhen@dhcp-- shell]$ grep words -b -o n
:words
:words
:words
[lizhen@dhcp-- shell]$

10,搜索多个文件并找出文本位于哪一个文件中,使用-l

[lizhen@dhcp-- shell]$ grep words n n1
n:this is a words file.
n:words words to be
n1:this is a words file.
n1:words words to be
[lizhen@dhcp-- shell]$ grep words -l n n1
n
n1
[lizhen@dhcp-- shell]$

使用-L  大写的L字符,取相反的结果

[lizhen@dhcp-- shell]$ grep words n n1
n:this is a words file.
n:words words to be
n1:this is a words file.
n1:words words to be
[lizhen@dhcp-- shell]$ grep words -l n n1
n
n1
[lizhen@dhcp-- shell]$ grep words -L n n1
[lizhen@dhcp-- shell]$

11,递归搜索文件,使用-R -n  (-n选项表示显示所在文件名:行号)

[lizhen@dhcp-- shell]$ grep words . -R -n
./n::this is a words file.
./n::words words to be
./n1::this is a words file.
./n1::words words to be
./n2::this is a words file.
./n2::words words to be
[lizhen@dhcp-- shell]$

12,忽略样式中的大小写,使用-i

[lizhen@dhcp-- shell]$ grep WORDS -i n
this is a words file.
words words to be
[lizhen@dhcp-- shell]$

13,使用grep匹配多个样式,使用-e

[lizhen@dhcp-128-93 shell]$ grep -e words  -e www -o n
words
words
words
www
www
www
www
[lizhen@dhcp-128-93 shell]$

14,使用样式文件,利用grep逐行读取样式文件,grep会将匹配到的行输出

[lizhen@dhcp-- shell]$ grep -f f n
this is a words file.
words words to be
, , , , , , , , , , www.regexper.com
www.google.com
www.baidu.com
www.redhat.com
[lizhen@dhcp-- shell]$

15,在grep搜索中指定或排除文件

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

#grep "main()" . -r --exclude "readme"

16,grep 的静默输出,使用-q

#########################################################################
# File Name: begin.sh
# Author: lizhen
# mail: lizhen_ok@.com
# Created Time: Wed May :: PM CST
#########################################################################
#!/bin/bash
if [ $# -ne ]
then
echo "usage: $0 match_text filename"
exit
fi match_text=$
filename=$
grep -q "$match_text" $filename if [ $? -eq ]
then
echo "The text exists in the file"
else
echo "text does not exist in the file"
fi echo "done!"
[lizhen@dhcp-- shell]$ ./begin.sh words n
The text exists in the file
done!
[lizhen@dhcp-- shell]$

17,打印匹配行之前或之后的行,使用-B,-A,-C选项

[lizhen@dhcp-- shell]$ grep www -B  n
this is a line containing pattern
,.<>?;';;;' [] {= = \ \ \| -__!@#$%^&*() !@#$$%%^&*(()*&%@(#$%)) www.regexper.com
www.google.com
www.baidu.com
www.redhat.com
[lizhen@dhcp-- shell]$ grep www -B n www.regexper.com
www.google.com
www.baidu.com
www.redhat.com
[lizhen@dhcp-- shell]$ grep www n
www.regexper.com
www.google.com
www.baidu.com
www.redhat.com
[lizhen@dhcp-- shell]$
[lizhen@dhcp-- shell]$ grep words -A   n
this is a words file.
words words to be
, , , , , , , , , ,
[lizhen@dhcp-- shell]$
[lizhen@dhcp-- shell]$ grep  n

[lizhen@dhcp-- shell]$ grep  n -C
beginning linux programming 4th edition [lizhen@dhcp-- shell]$
												

文本处理grep命令的更多相关文章

  1. Linux命令-文件文本操作grep

    文件文本操作 grep 在文件中查找符合正则表达式条件的文本行 cut 截取文件中的特定字段 paste 附加字段 tr 字符转换或压缩 sort 调整文本行的顺序,使其符合特定准则 uniq 找出重 ...

  2. 【OS_Linux】三大文本处理工具之grep命令

    grep(global search regular expression(RE) and print out the line,整行搜索并打印匹配成功的行 语法:grep  [选项]   搜索词  ...

  3. linux grep命令

    linux grep命令1.作用Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来.grep全称是Global Regular Expressio ...

  4. linux管道命令grep命令参数及用法详解---附使用案例|grep

    功能说明:查找文件里符合条件的字符串. 语 法:grep [-abcEFGhHilLnqrsvVwxy][-A<显示列数>][-B<显示列数>][-C<显示列数>] ...

  5. grep 命令详解

    [root@www ~]# grep [-acinv] [--color=auto] '搜寻字符串' filename 选项与参数: -a :将 binary 文件以 text 文件的方式搜寻数据 - ...

  6. grep 命令操作

    linux grep命令 1.作用Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来.grep全称是Global Regular Expressi ...

  7. Linux命令(23)grep命令的使用

    grep(global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正 ...

  8. 每天一个linux命令(39):grep 命令

    Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来.grep全称是Global Regular Expression Print,表示全局正则表达 ...

  9. 由一条Linux的grep命令说起

    今天在开发的时候,看到同事使用了这样的一条linux命令 grep 'class YourClass' -rwi * |grep -v svn 想到了 grep命令的,几个参数. -r 明确要求搜索子 ...

随机推荐

  1. Q9400为何难以100%全速运行

    采用基于正域的约简. 数据:Ticdata2000 记录数:5822 条件属性:85 结果: 1. Core i7 3632QM 4四核八线程 2.2G 动态加速3.2G 0.516s 2. Core ...

  2. Luogu P5008 逛庭院

    题目传送门 我校神仙出的神仙题 \(\%\%\%\) 30分 找出所有有入度的点,排序,选前\(k\)个点,好了,30分到手. #include<iostream> #include< ...

  3. 转:Python字典与集合操作总结

    转自:http://blog.csdn.net/business122/article/details/7537014 一.创建字典 方法①: >>> dict1 = {} > ...

  4. 跟我一起从零开始学WCF系列课程

    http://www.microsoft.com/china/msdn/events/webcasts/shared/webcast/Series/WCF_Begin.aspx 服务和协定 服务协定使 ...

  5. 操作系统(6)_虚拟存储管理_李善平ppt

    image含各种段. 有些不需要的页可能永远不需要装入内存,可能只有百分之70-80是异常情况采用的,这种代码就可以放入硬盘. 抖动实际就是进程数太多导致内存不够用造成的. 页面换入换出在内存和磁盘之 ...

  6. https及其背后的加密原理阅读总结

    https是以安全为目标的http通道,简单讲是http的安全版.当我们往服务器发送比较隐私的数据(比如说你的银行卡,身份证)时,如果使用http进行通信.那么安全性将得不到保障. 首先数据在传输的过 ...

  7. restful api 规范

  8. shell基础及变量符号

    kernel主要的功能: 1.内存的管理 2.设备驱动程序 3.文件系统的管理 4.进程的管理 5.网络系统   vim /etc/profile.d/ profile(主配置文件) .d(子配置文件 ...

  9. HTML5/CSS3 第三章页面布局

    页面布局 1 页面组成 2 布局相关的标签 <div></div> 定义文档中的分区或节 <span></span> 这是一个行内元素,没有任何意义 & ...

  10. awk速查手册

    简介awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进 ...