Linux命令:grep命令 | egrep命令
grep:文本搜素工具,根据用户指定的文本模式对目标文件进行逐行搜索,显示能被模式所匹配到的行
包含三个命令:grep、egrep(相当于grep -E 扩展的正则表达式)和fgrep(相当于grep -F 只能字符串匹配)
格式:
grep [options] PATTEN filename
options
grep -v (--invert-match):反向匹配,显示不能被表达式匹配的行
grep -o (--only-matching):仅显示被模式匹配到的字串,而非整行,将匹配到的字符串一行一个显示
grep -n :打印行号
grep -q:静默模式,不输出任何信息,用于写脚本时的判断,和&>/dev/null一样
grep -c :计算找到匹配项的行数,1行算1次。只显示行数,不显示匹配到的行内容
grep -i :不区分字符大小写
grep -B 数字:before显示匹配行,和其上面n行
grep -A 数字:after显示匹配行,和其下面n行
grep -C 数字:显示匹配行,和上下n行
grep -e :实现多个选项间的逻辑or关系,例如grep -e 'cat' -e 'dog' filename
grep -w :匹配整个词,用空格、特殊符号隔开的都算一个词
grep -f 后面跟文件,文件中写正则表达式,各个表达式相当于或关系
grep -f f1 f2 #两个文件取交集
grep -E 使用egrep
grep -F 使用fgrep
PATTEN正则表达式:是一类字符所书写出的模式(pattern)
元字符:不表示字符本身的意义,用于额外功能性的描述
基本正则表达式(grep)的元字符:
字符匹配:
.:元字符,代表任意一个字符,包括空格
\.:表示.本身,"\"斜杆是逃逸符后面可接, ! ` [ .
[ ]:指定范围内的任意单个字符
[^]:指定范围外的任意单个字符
[A-Z],[[:upper:]]所有大写字母
[a-z],[[:lower:]]所有小写字母,和通配符匹配文件名有区别
[[:alpha:]]所有字母,大小写
[0-9],[[:digit:]]所有数字
[[:alnum:]]所有数字+字母
[[:blank:]]空白字符(空格和制表符)
[[:space:]]水平和垂直的空白字符(比[:blank:]包含的范围广)
[^[:space:]]非空白字符
[[:graph:]]可打印的非空白字符
[[:print:]]可打印字符
[[:punct:]]标点符号
[[:cntrl:]]不可打印的控制字符(退格、删除、警铃)
次数匹配:用来指定匹配其前面的字符的次数
*:任意次
例如:x*y,xxy,xy,y,指的是x可以出现0,1或者多次
.*:匹配任意长度的任意字符
\?:0次或1次
例如:x\?y,xy,y,xxy
贪婪模式:尽可能的长的去匹配字符
\+:至少1次
\{m\}:匹配m次,此处的两个\\是转义字符
\{m,n\}:匹配至少M次,至多n次
\{m,\}:匹配至少M次
\{0,n\}:匹配至多n次
例如:x\{2,6\}y匹配xxy,xxxy,xxxxy,xxxxxy,xxxxxxy
位置锚定:用于指定字符出现的位置
^:锚定行首
$:锚定行尾
例如:^[[:space:]]\+$ 空白组成的行
\<char:锚定词首,\bchar 数字、字母、下划线连起来的都算单词,其他符号都算分隔符
char\>:锚定词尾,char\b
例如: \<h..o\>,以h开头,o结尾中间跟任意两个字符的单词
分组:
\(\)
\(ab\)*xy xy,abxy,ababxy
引用:
\1:后向引用,引用前面的第一个左括号以及与之对应的右括号中的模式的结果字符串
\2
\(a.b\)xy\1 a6bxya6b
或者:
\| a\|bcd a或者bcd,整个字符串或者
举例:
、显示/proc/meminfo文件中以大小写s开头的行
# grep "^[Ss]" /proc/meminfo
# grep -i "^s" /proc/meminfo 、取出默认shell为非bash的用户
# grep -v "bash$" /etc/passwd | cut -d: -f 、取出默认shell为bash的且ID号最大的用户
# grep "bash$" /etc/passwd | sort -t: -k3 -rn|head -|cut -d: -f1 、显示/etc/rc.d/rc.sysinit文件中,以#开头,后面至少一个空白字符,而后至少一个非空白字符的行
# grep "^#[[:space:]]\{1,\}[^[:space:]]\{1,\}" /etc/rc.d/rc.sysinit 、显示/boot/grub/grub.conf中至少一个非空白字符开头的行
# grep "^[^[:space:]]\{1,\}" /boot/grub/grub.conf 、找出/etc/passwd文件中一位数或两位数
# grep "\<[0-9]\{1,2\}\>" /etc/passwd 、查看当前系统上root用户的所有信息
# grep "^root\>" /etc/passwd 、添加用户bash和testbash、basher,而后找出当前系统上其用户名和默认shell相同的用户
# grep "^\([[:alnum:]]\{1,\}\)\>.*\1$" /etc/passwd 、匹配所有非空白行
#grep "." a.txt 、取目录名
# grep -Eo ".*\<"
# grep -Eo ".*[^/]" | grep -Eo ".*/" 、取基名
# grep -Eo "[^/]+/?$" 、匹配空行
# grep ^$ file 、匹配非空行
# grep -v ^$ file 或 grep .\+ file 、匹配0.0.0.~255.255.255.255
grep --color=auto -o "\(\<\([0-9]\|[1-9][0-9]\|1[0-9]\{2\}\|2[0-4][0-9]\|25[0-5]\)\>\.\)\{3\}\<\([0-9]\|[1-9][0-9]\|1[0-9]\{2\}\|2[0-4][0-9]\|25[0-5]\)\>" 、匹配实际IP地址1.0.0.-223.255.255.255
grep --color=auto -o "\<\([1-9]\|[1-9][0-9]\|1[0-9]\{2\}\|2[0-1][0-9]\|22[0-3]\)\>\(\.\<\([0-9]\|[1-9][0-9]\|1[0-9]\{2\}\|2[0-4][0-9]\|25[0-5]\)\>\)\{3\}"
egrep:使用扩展正则表达式来创建模式,相当于 grep -E
元字符:
字符匹配:
.:任意单个字符
[ ]:指定范围内的任意单个字符
[^ ]:指定范围外的任意单个字符
次数匹配:
*:匹配其前面的字符任意次
?:匹配前面的字符0或1次
+:匹配前面的字符至少1次
{m}:匹配前面的字符m次 区别于普通正则表达式
{m,n}:至少m,至多n次
{m,}:至少m次
{0,n}:至多n次
锚定
^:行首
$:行尾
\<, \b :词首
\>, \b :词尾
分组:
():分组
Linux命令:grep命令 | egrep命令的更多相关文章
- Linux中grep和egrep命令详解
rep / egrep 语法: grep [-cinvABC] 'word' filename -c :打印符合要求的行数-i :忽略大小写-n :在输出符合要求的行的同时连同行号一起输出-v ...
- grep、egrep命令用法
何谓正则表达式 正则表达式,又称正规表示法.常规表示法(Regular Expression,在代码中常简写为regex.regexp或RE),是一类字符所书写的模式,其中许多字符不表示其字面意义,而 ...
- Linux正则表达式grep与egrep
grep -io "http:/=[A-Z0-9]\{16\}" ./wsxf.txt >wsxf_urls.txt Linux正则表达式grep与egrep 正则表达式:它 ...
- Linux常用命令学习2---(文件搜索命令locate find、命令搜索命令whereis which、字符串搜索命令grep、帮助命令man)
1.文件搜索命令:locate [文件名] 在后台数据库中按文件名搜索,搜索速度比find快,耗费资源更少 例子:locate test.txt,就会显示文件名包含 test.txt的所 ...
- linux中grep和egrep的用法
1. grep简介 grep (global search regular expression_r(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大 ...
- grep与egrep命令
greo -E 等同于 egrep grep常用两种方式 1. grep -c python a.txt 2. cat a.txt | grep -c python a.txt文件如下 i l ...
- linux中grep命令的使用
转载:http://blog.csdn.net/universsky/article/details/8866402 linux中grep命令的使用 grep (global search regul ...
- Linux学习日志--文件搜索命令
开头总结: 学习了Linux中的文件搜索命令find和locate,系统搜索命令whereis 和which ,字符串搜索命令grep,find和locate的差别和使用方法格式,什么是path环境变 ...
- Linux grep/egrep命令详解
grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来 grep搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文件不存在,则返回2. grep的规则表达式( ...
随机推荐
- ARM架构Linux环境安装python2.7.9
1.下载python # wget https://www.python.org/ftp/python/2.7.9/Python-2.7.9.tgz 2.解压.编译安装 # tar -zxvf Pyt ...
- datatable自动增加序号
{ "targets": [0], "visible": true, "render": function (data, type, ful ...
- 解决idea无法下载通过maven添加的jar包以及下载网速过慢的问题
在idea上使用Maven来添加依赖的jar包 发现无法下载jar包 总是提示某几个包下载失败 最后发现原因有两个(版本与网速的问题 对应解决如下) 一主要是因为版本的问题 我的idea是2019年1 ...
- redis(一)动态字符串
redis 动态字符串 概述 Sda(Simple Dynamic String) 简单动态字符串是 redis中用来表示字符串的结构,而不是传统 C 字符串. 主要的特点就是Sda要做到高效和 二进 ...
- Django 单元测试笔记
引言 关于单元测试的基本知识这里不再讲述,简单一句话:单元测试是用一段代码去测试另一段代码.最常用的框架是unittest,这是python的单元测试框架,而django单元测试框架test.Test ...
- Java常用API——Arrays工具类
介绍:Arrays工具类提供了一些可以直接操作数组的方法,以下是一些常用方法: int binarySearch(type[] a, type key):要求数组a元素升序排列,使用二分法搜索key的 ...
- .NET中的字符串(4):字符串 - 特殊的引用类型
字符串驻留 看一下这段代码: 1using System; 2 3namespace Demo4 4{ 5 /**//// <summary> 6 /// String的驻留 7 /// ...
- Linux 一些有用的能力
编程能力 Linux产生于一群真正的黑客.尽管人们习惯于认为Linus是Linux的缔造者,在linux包含的数以千计的文件中,也有一个名为Credits的文件记录了主要的Linux Hacker们的 ...
- 爬虫必备工具-chrome 开发者工具
在某个网站上,分析和抓取数据,我们用的最多的工具就是 Chrome 开发者工具 01 元素面板 通过元素(Element)面板,我们能查看发哦想抓取页面渲染内容所在的标签.使用什么 CSS 属性(例如 ...
- GRE Over IPSec配置
路由器GRE over IPSec站点到站点VPN 问题分析:对于前面的经典的IPSec VPN的配置来说,兼容性较好,适合于多厂商操作的时候,但是这种经典的配置方式不适合在复杂的网路 ...