【1.0 Regular Expressions 正则表达式】
【概念】
RegEx
正则表达式是一种特殊的字符序列,可帮助您使用专门的模板语法,来匹配对应的匹配方法或字符串组
它们可用于搜索,编辑或操纵文本和数据
正则表达式通常用于验证输入和检索信息
比如我们要寻找一个"car",那么在下面几种情况都可以利用正则表达式:
1.car 作为独立的一个单词出现
2.car 是某个单词的一部分,比如说carton就是含"car"的单词
3.car 中c,a,r按顺序出现在一个单词里面,比如,chandler
可以认为,RegExV是用广泛使用的正式语言写的,一种简洁的字符串匹配方法
【使用】
使用RegEx的方法主要是使用matches(),比如
boolean bool = "abbbb" . matches("ab8")
如你所见,这个方法会得到一个boolean值
下面演示几种用法,problem代表要检查的语句,可以直接使用string
"problem".matches(RegEx)
“abc”.matches(“abc”)
“Abc”.matches(“Abc”)
“Abc”.matches(“abc”) //false
“aabbaba”.matches(“[ab]*”)
“aabbaba”.matches(“a[ab]*”)
“bbaba”.matches(“a[ab]*”)//false
【语法】
1.完全相连的字母,比如abc,需要完全匹配(含大小写)
2.用[]括起来的,代表可以用[]里面的其中一个字母代替,同样适用于大小写的替代,比如[Dd]
比如ca[bdn],就可以用cab,cad,can来匹配
3.使用^代表Not,非
比如,ca[^brt],就 不能 用cab,car,cat匹配
此外,^不可以被用于匹配第一个字符
【语法:范围】
[a-z] 任意小写字母
[A-Z] 任意大写字母
[aA-zZ] 任意大小写字母
[0-9] 任意数字
[a-z&&[^xyz]] 从a-z,但是不含x,y,z
[a-zA-Z0-9] 任意大小写字母或数字
【语法:数量】
:代表出现0次/没有出现,或者出现很多次,比如
ab a ab abb abbbb
[ab]* aa aabbababbaaabbabaabba bbba
+:出现一次或者很多次
ab+ ab abb abbbb
?:代表出现0次或者一次
Colou?r Colour Color (?作用于u)
【语法:“清点”】
x{3} // 只有xxx
x{3,} // 大于等于三次就可以xxx xxxxxxxxxxxx...
x{2,4} // 有两次到四次都可以,xx, xxx and xxxx
.[a-z]{2,4} //代表这从点. 开始,后跟2-4的字母,比如 (.ie .com .info)
【语法:通配】
点, .是通配符,它允许字符串中的任何字符(除了换行符也就是回车)
re.d //匹配 read reed rezd
【语法:反斜杠与特殊字符】
使用反斜杠,会让“反斜杠后跟的特殊字符”变成“普通字符”,
比如.和\. 后者就是普通字符的意思
"www.4399.com".matches("www\\.[a-zA-z]+||.[a-z]{2,4}")
按理来说,只要.就可以代表普通字符点.了,那么为什么需要两个斜杠呢,见下方的“单词word”部分
•“ab”c” 需要写成 “ab\”c”
•“ab””c” 需要写成 “ab\”\”c”
•“ab\c” 需要写成 “ab\c”
•“ab\c” 需要写成 “ab\\c”
【语法:单词word】
反斜杠\加上字符是一个特殊字符,“单词word”是字母数字字符和下划线的非空序列
“the backslash \character is a special character. It means, do Not treat the following character in the normal way”
“反斜杠\字符是一个特殊字符。它的意思是,不要以正常的方式输入下面的字符”(\.就是这个原因)
“ \\.实际上被转义为两次,\\在java中被转换为一个'\'字符,然后'\.'被传给正则,\.表示对点字符进行转义,使.就表示字符'.',而不使用它在正则中的特殊意义”
就像上面这句话,实质上在预览中只看得到两个斜杠一个点,两个斜杠,一个斜杠,一个斜杠一个点,一个斜杠一个点。这里也利用了类似的办法是反斜杠变成了普通字符
. 句号,停止符号。另外这个规则意味着如果我们想要匹配一个点,需要输入"\."
\b 词语边界
\s 空格
\ 反斜杠与字符
\t 制表字符
\d 数字
\w word字符
【PDF里面的列表图片,24页】
【java.util.regexpackage】
以下内容需要配合java.util.regexpackage使用,也算可以先不看的额外内容
Pattern Class :Pattern对象是正则表达式的编译表示,Pattern类不提供公共构造函数。要创建一个pattern,必须首先调用其公共静态compile()方法之一,然后再返回一个Pattern对象,这些方法接受正则表达式作为第一个参数
Matcher Class : Matcher对象是解释模式并针对输入字符串执行匹配操作的引擎,与Pattern类一样,Matcher也没有定义公共构造函数。您可以通过在Pattern对象上调用matcher()方法来获得Matcher对象
PatternSyntaxException: 指示正则表达式模式中的语法错误的未检查的异常
捕获组Capturing Groups:
捕获组是将多个字符视为一个单元的一种方式。通过将要分组的字符放在一组括号中来创建它们。
例如,正则表达式(dog)创建一个包含字母“ d”,“ o”和“ g”的单个组
捕获组的编号是从左到右计算它们的开括号
((A)(B(C)))有四个组,((A)(B(C))) , (A) ,(B(C)) ,(C)
groupCount():
为了找出表示该表达式中有多少个组,请调用“ groupCount”方法匹配对象。“ GroupCount”方法返回i\一个int,以显示该匹配器模式matcher'spattern中存在的捕获组数
还有一个特殊的组,组0,始终代表整个表达式。该组不包括按组计数报告的总数。
(更多方法和实例详见PDF的27 - 41 页)
(编写这部分内容的时候,对markdown还不够熟练,可能有bug,请指出)
【1.0 Regular Expressions 正则表达式】的更多相关文章
- 自学Zabbix8.1 Regular expressions 正则表达式
点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 自学Zabbix8.1 Regular expressions 正则表达式 1. 配置 点击Adm ...
- Regular Expressions --正则表达式官方教程
http://docs.oracle.com/javase/tutorial/essential/regex/index.html This lesson explains how to use th ...
- 正则表达式(Regular expressions)使用笔记
Regular expressions are a powerful language for matching text patterns. This page gives a basic intr ...
- 正则表达式备忘录-Regular Expressions Cheatsheet中文版
正则表达式备忘录Regular Expressions Cheatsheet中文版原文:https://www.maketecheasier.com/cheatsheet/regex/ 测试文件a.t ...
- Python之Regular Expressions(正则表达式)
在编写处理字符串的程序或网页时,经常会有查找符合某些复杂规则的字符串的需要.正则表达式就是用于描述这些规则的工具.换句话说,正则表达式就是记录文本规则的代码. 很可能你使用过Windows/Dos下用 ...
- 转载:邮箱正则表达式Comparing E-mail Address Validating Regular Expressions
Comparing E-mail Address Validating Regular Expressions Updated: 2/3/2012 Summary This page compares ...
- Regular Expressions in Grep Command with 10 Examples --reference
Regular expressions are used to search and manipulate the text, based on the patterns. Most of the L ...
- Introducing Regular Expressions 学习笔记
Introducing Regular Expressions 读书笔记 工具: regexbuddy:http://download.csdn.net/tag/regexbuddy%E7%A0%B4 ...
- 【Python学习笔记】Coursera课程《Using Python to Access Web Data 》 密歇根大学 Charles Severance——Week2 Regular Expressions课堂笔记
Coursera课程<Using Python to Access Web Data > 密歇根大学 Charles Severance Week2 Regular Expressions ...
随机推荐
- ts 索引签名 无视多余的属性类型
interface SquareConfig { color?: string; width?: number; [propName: string]: any; } function asd(opt ...
- NGK创造的BGV金融世界观是什么?
目前DeFi已经形成初级的金融体系.笔者将DeFi市场对比传统金融世界观,不过市场结构有显着差异.我们可以这样想:如果在去中心化金融世界中借钱,那么可以把MakerDAO比作为中央银行(+回购). 去 ...
- Recycle 只显示一行BUG
学习Recycle 两天了,照着网上的Adapter写了2个Demo,结果测试的时候发现,第一个Demo 显示.点击都正常,第二个Demo的Adapter合第一个一模一样,仅仅是类名不同,结果显示的时 ...
- PacketStream 和 honeygain 推荐一款可以通过分享带宽赚钱的APP
方法很简单,只需打开网址 PacketStream 或 honeygain 注册,下载客户端登录即可分享带宽.价格0.1美元/G. 绑定paypal账号即可提现.退出客户端即可停止分享带宽.
- springboot的4种属性注入
1.Autowired注入 2.构造方法注入 3.@Bean方法形参注入 4.直接在@Bean方法上使用注解@ConfigurationProperties(prefix="jdbc&quo ...
- Azure Functions(三)集成 Azure Queue Storage 存储消息
一,引言 接着上一篇文章继续介绍 Azure Functions,今天我们将尝试绑定 Queue Storage,将消息存储到 Queue 中,并且学会适用于 Azure Functions 的 Az ...
- 剑指 Offer 14- I. 剪绳子 + 动态规划 + 数论
剑指 Offer 14- I. 剪绳子 题目链接 还是343. 整数拆分的官方题解写的更清楚 本题说的将绳子剪成m段,m是大于1的任意一个正整数,也就是必须剪这个绳子,至于剪成几段,每一段多长,才能使 ...
- JavaScript初级学习
1. JavaScript的介绍 前身是LiveScript+JavaScript JavaScript(js)是一个脚本语言 基于浏览器的脚本语言 基于对象,面向对象的一个编程语言 2. EcmaS ...
- [DP浅析]线性DP初步 - 2 - 单调队列优化
目录 #0.0 前置知识 #1.0 简单介绍 #1.1 本质 & 适用范围 #1.2 适用方程 & 条件 #2.0 例题讲解 #2.1 P3572 [POI2014]PTA-Littl ...
- Python工程师学习之旅
1.Python软件开发基础 1.Linux操作系统2.Docker基础3.Python基础语法4.Python字符串解析5.Python正则表达式6.Python文件操作7.Python 模块8.P ...