henry1998

grep和正则表达式

grep

linux三剑客之一,文本过滤器(根据文本内容过滤文件)

语法格式:
	grep [参数] [匹配规则] [操作对象]

参数;
	-n : 过滤文本时,将过滤出来的内容在文件内的行号显示出来
	-A : 匹配成功之后,将匹配行的后n行显示出来
	-B : 匹配成功之后,将匹配行的前n行显示出来
	-C : 匹配常规之后,将匹配行的前后各n行显示出来
	-c : 只显示匹配成功的行数
	-o : 只显示匹配成功的内容
	-v : 反向过滤
	-q : 静默输出
	-i : 忽略大小写
	-l : 匹配成功之后,将文件的名称打印出来
	-R|-r : 递归匹配
	
	-E : 使用拓展正则 等价于egrep
	
知识储备:
	$? : 上一行命令执行的结果,0代表执行成功,其他数字代表执行失败
	wc : 匹配行数
		-l : 打印匹配行数
		-c : 打印匹配的字节数
		
在/etc目录下,有多少文件包含root
	grep -rl \'root\' /etc/ | wc -l

正则表达式

1、正则表达式的分类(grep)
	1、普通正则表达式
	2、拓展正则表达式

2、普通正则表达式
	
	^ : 以某字符开头
	$ : 以某字符结尾
	. : 匹配除换行符之外的人以单个字符
	* : 匹配前导字符的任意个数
	[] : 某组字符串的任意一个字符
	[^] : 取反
	[a-z] : 匹配小写字母
	[A-Z] : 匹配大写字母
	[a-zA-Z] : 匹配字母
	[0-9] : 匹配数字
	\ : 取消转义
	() : 分组
	\n : 代表第n个分组
	
3、拓展正则
	{}	:	匹配的次数
	{n}	:	匹配n次
	{n,}	:	至少匹配n次
	{n,m}	:	匹配n次到m次
	{,m}	:	最多匹配m次
	+	:	匹配至少有一个前导字符
	?	:	匹配一个或零个前导字符
	|	:	或
	
案例:
	案例1:在/etc/passwd文件中,匹配一ftp开头的行
		grep \'^ftp\' /etc/passwd
	案例2:在/etc/passwd文件中。匹配以bash结尾的行
		grep \'bash$\' /etc/passwd
	案例3:匹配本机中有那些ip
		ip a | grep -oE \'([0-9]{1,3}\.){3}[0-9]{1,3}\'
	案例4:要求将/etc/fstab中的取消包含 # 开头的行,且要求 # 后中少有一个空格
		grep -vE \'^#\ +\' /etc/fstab
	案例5:找出文件中至少有一个空格的行
		grep -E \'\ +\' xxx
	案例6:将nginx.conf 文件中以 #开头的行和空行 全部删除
		grep -vE \'^\ *#|^$\' /etc/nginx/nginx.conf

分类:

技术点:

相关文章:

  • 2022-12-23
  • 2021-12-13
  • 2021-12-13
  • 2021-12-13
  • 2021-12-13
  • 2021-12-13
猜你喜欢
  • 2021-10-29
  • 2021-12-13
  • 2021-09-05
  • 2021-12-12
  • 2021-12-11
相关资源
相似解决方案