首页 > 其他分享 >正则表达式

正则表达式

时间:2022-12-02 11:58:44浏览次数:46  
标签:字符 grep love 正则表达式 匹配 元字符

正则表达式
	正则表达式(regular expression,RE) 是一种字符模式,用于在查找过程中匹配指定的字符。
	在大多数程序里,正则表达式都被置于两个斜杠之间;例如/l[oO]ve/就是由正斜杠界定的正则表达式
	它将匹配被查找的行中任何位置出现的相同模式。在正则表达式中,元字符是最重要的概念。
	举例
		匹配数字:^[0-9]+$
		匹配email:[a-z0-9_]+@[a-z0-9]+\.[a-z]+
		匹配IP:[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}
				或
				[[:digit:]]{1,3}\.[[:digit:]]{1,3}\.[[:digit:]]{1,3}\.[[:digit:]]{1,3}

元字符
	定义:元字符是这样一种字符,它们表达的是不同于字面本身的含义
	shell元字符(也称为通配符) 由shell来解析,如rm -rf *.pdf,元字符*shell将其解析为任意多个字符
	正则表达式元字符  由各种执行模式匹配操作的程序来解析,比如vi、grep、sed、awk

	vim示例
	:1,$ s/tom/David/g  #把tom替换
	:1,$ s/\<[Tt]om\>/David/g #tom Tom都会替换

  

正则表达式元字符
#基本正则表达式元字符
元字符		功能		示例
============================================================================
^			行首定位符			^love
$			行尾定位符			love$
.			匹配任意单个字符	l..e
*			匹配前导符0到多次	ab*love
.*			任意多个字符
[]			匹配指定范围内的一个字符	[iL]ove
[ - ]		匹配指定范围内的一个字符	[a-z0-9]ove
[^]			匹配不在指定组内的字符		[^a-z0-9]ove
\			用来转义元字符		love\.
\<			词首定位符			\<love		#类似于\b '\<love\>'='\blove\b'
\>			词尾定位符			love\>
\(..\)\		匹配稍后使用的字符的标签	:% s/172.16.130.1/172.16.130.5/
										:% s/\(172.16.130.\)1/\15/
										:% s/\(172.\)\(16.\)1/\1\25/
x\{m\}		字符x重复出现m次	o\{5\}
x\{m,\}		字符x重复出现m次以上		o\{5,\}
x\{m,n\}	字符x重复出现m次到n次		o\{5,10\}

======================扩展元字符=============================================
+			匹配一个或多个前导字符		[a-z]+ove
?			匹配零个或一个前导字符		lo?ve
a|b			匹配a或b					love|hate
()			组字符						
(..)(..)\1\2标签匹配字段				(love)able\1er
x{m}		字符x重复m次				o{5}
x{m,}		字符x重复m次以上			o{5,}
x{m,n}		字符x重复m次到n次			o{5,10}

=====================POSIX字符类=============================================
表达式			功能				示例
[:alnum:]		字母与数字字符		[[:alnum:]]+     #类似\w 'L\wve';\W 字母与数字之外的字符,称为非字符 '\love\W+'
[:alpha:]		字母字符(包括大小写)[[:alpha:]]{4}
[:blank:]		空格与制表符		[[:blank:]]*
[:digit:]		数字字母			[[:digit:]]?
[:lower:]		小写字母			[[:lower:]]{5,}
[:upper:]		大写字母			[[:upper:]]+
[:punct:]		标点符号			[[:punct:]]
[:space:]		包括换行符、回车等在内的所有空白	[[:space:]]+

#正则匹配示例:vim
/love/
/^love/
/love$/
/l.ve/
/lo*ve/
/[Li]ove/
/love[a-z]/
/love[^a-zA-Z0-9]/
/.*/
/^$/  #空行 等同于/^[ \t]*$/
/^[A-Z]..$/
/^[A-Z][a-z]*3[0-5]/
/[a-z]*\./
#注释行
/^#/
/^[ \t]*#/

  

grep家族
	grep: 在文件中全局查找指定的正则表达式;grep也可使用扩展集中的字符,仅需要对这些元字符前置一个反斜线
	egrep: 扩展的grep ,支持更多的正则表达式元字符 ;或者grep -E 使用扩展元字符集
	fgrep: 固定grep,也被称作快速,它按字面解释所有字符

#grep命令格式
#grep [选项] pattern filename1 filename2
#grep 'Tom' /etc/passwd
#	找到:	grep返回退出状态为0
#	没找到:	grep返回的退出状态为1
#	找不到指定文件:grep返回的退出状态为2

#grep选项
-i 		#忽略大小写
-l		#列出匹配行所在的文件名
-n		#每行加上行号
-c  	#显示匹配成功的行数
-q		#静默
-v		#反向查找,只显示不匹配的行
-R,-r	#递归针对目录
-B		#前几行
-A		#后几行
-C		#前后几行

  

标签:字符,grep,love,正则表达式,匹配,元字符
From: https://www.cnblogs.com/smatter/p/16943999.html

相关文章

  • 收藏:关于正则表达式的的一些经验
    匹配中文字符的正则表达式:[\u4e00-\u9fa5]评注:匹配中文还真是个头疼的事,有了这个表达式就好办了匹配双字节字符(包括汉字在内):[^\x00-\xff]评......
  • java-正则表达式
    1.一般流程Patternp=Pattern.compile("a*b");Matcherm=p.matcher("aaaaab");booleanb=m.matches();或booleanb=Pattern.matches("a*b","aaaaab");booleanb......
  • go 正则表达式
    funcmain(){ line:="2022/11/2519:32<DIR>目录" reg:=regexp.MustCompile(`([\d/]+)\s+(\d+:\d+)\s+(<DIR>)\s+(.*)`) ifreg==nil{ panic(......
  • 使用正则表达式处理字符串
    参考代码:mportrestrInput='310.1'strList=re.findall('^[\-\+]?\d+\.?\d+$',strInput)print(strList)strInput2='aa310.0.1'strList2=re.search('[\-\+......
  • Python高级-正则表达式-笔记
    1.re模块操作在Python中需要通过正则表达式对字符串进行匹配的时候,可以使用一个模块,名字为re1.re模块的使用过程#coding=utf-8#导入re模块importre#使用mat......
  • 正则表达式的Wed验证应用(40)
    电子邮件地址的校验<?php/*校验邮件地址*/functioncheckMail($email){//用户名,由“\w”格式字符、“-”或“.”组成$email_name="\w|(\w[-.\w]*\w)";//域名中的第一段,规......
  • c# paddleorcsharp批量图片文字识别,拖拽实现,正则表达式提取
    usingPaddleOCRSharp;usingSystem;usingSystem.Collections.Generic;usingSystem.ComponentModel;usingSystem.Data;usingSystem.Drawing;usingSystem.Linq;......
  • 大数据之脚踏实地学18--Scala正则表达式的使用
    前言在《​​大数据之脚踏实地学17--Scala字符串的清洗​​》一文中我们介绍了Scala语言中常用的字符串处理方法,但这些方法并不是万能的,例如字符串子串的获取,如果目标子串并......
  • 编辑器常用正则表达式
    编辑器常用正则表达式匹配空格表达式:^\s?|\s+匹配截至空格表达式:^\s?|\s+$匹配空行根据文档格式和系统(windows,mac,linux行尾符)不同将其中的\r\n替换成不同......
  • 0123-Go-正则表达式
    环境Time2022-08-25Go1.19前言说明参考:https://gobyexample.com/regular-expressions目标使用Go语言的正则表达式。示例packagemainimport( "bytes" ......