正则表达式详解


一、什么是正则表达式

正则表达式,又称规则表达式,(Regular Expression,在代码中常简写为regex、regexp或RE),是一种文本模式,包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称为"元字符"),是计算机科学的一个概念。正则表达式使用单个字符串来描述、匹配一系列匹配某个句法规则的字符串,通常被用来检索、替换那些符合某个模式(规则)的文本。

二、使用详解

1.[]:表示一个字符,该字符可以是[]中指定的内容

例如:
       [abc]:这个字符可以是a或b或c
       [a-z]:表示任意一个小写字母
       [a-zA-Z]:表示任意一个字母
       [a-zA-Z0-9]:表示任意一个字母数字
       [a-zA-Z0-9_]:表示任意一个数字字母下划线
       [^abc]:该字符只要不是a或b或c

2.预定义字符

        . :表示任意一个字符,没有范围限制
       \d:表示任意一个数字,等同于[0-9]
       \w:表示任意一个单词字符,等同于[a-zA-Z0-9_]----单词字符指字母、数字和_
       \s:表示任意一个空白字符
       \D:不是数字
       \W:不是单词字符
       \S:不是空白字符

 3.量词

       ?:表示前面的内容出现0-1次
         例如: [abc]? 可以匹配:a 或 b 或 c 或什么也不写
               但是不能匹配:m或aaa
       +:表示前面的内容最少出现1次
         例如: [abc]+ 可以匹配:b或aaaaaaaaaa...或abcabcbabcbabcba....
               但是不能匹配:什么都不写 或 abcfdfsbbaqbb34bbwer...
       *:表示前面的内容出现任意次(0-多次)---匹配内容与+一致,只是可以一次都不写
         例如: [abc]* 可以匹配:b或aaaaaaaaaa...或abcabcba....或什么都不写
               但是不能匹配:abcfdfsbbaqbb34bbwer...
       {n}:表示前面的内容出现n次
           例如: [abc]{3} 可以匹配:aaa 或 bbb 或 aab 或abc 或bbc
                但是不能匹配: aaaa 或 aad
       {n,m}:表示前面的内容出现最少n次最多m次
             例如: [abc]{3,5} 可以匹配:aaa 或  abcab 或者 abcc
             但是不能匹配:aaaaaa 或 aabbd
       {n,}:表示前面的内容出现n次以上(含n次)
            例如: [abc]{3,} 可以匹配:aaa 或 aaaaa.... 或 abcbabbcbabcba....
                 但是不能匹配:aa 或 abbdaw...             

4.()用于分组,是将小括号里面的内容看做是一个整体    


             例如: (abc){3} 表示abc整体出现3次. 可以匹配abcabcabc
             但是不能匹配aaa 或abcabc
             (abc|def){3}表示abc或def整体出现3次.
             可以匹配: abcabcabc 或 defdefdef 或 abcdefabc
             但是不能匹配abcdef 或abcdfbdef 

5.String支持与正则表达式相关的方法

   - matches():使用给定的正则表达式(regex)验证当前字符串的格式是否符合要求,若符合则返回true,否则返回false
   - replaceAll():将当前字符串中满足正则表达式(regex)的部分给替换为给定的字符串(s)
   - split():将当前字符串按照满足正则表达式(regex)的部分进行拆分,将拆分出的以String[]形式来返回
 


总结

以上就是今天要讲的内容,本文仅仅简单介绍了正则表达式的使用,正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值