美文网首页
java 正则表达

java 正则表达

作者: 往之_ | 来源:发表于2017-09-01 11:06 被阅读38次
    简单介绍

    java.util.regex 是一个用正则表达所制定的模式来对字符串进行匹配工作的类库包 ,
    两个类, Pattern 和 Matcher
    一个pattern 是一个正则表达式经编译后的表现模式
    Matcher 一个Matcher 对象是一个状态机器, 一局Pattern对象作为匹配模式对字符串展开匹配检查

    pattern 类

    pattern 类的方法:

           static Pattern compile(String regex); 
    

    将给定的正则表达式编译并且赋值给pattern类

        static Pattern compile(String regex, int flags) 
    

    可以增加flag 参数的指定 , 可选参数包括 CASE INSENSITIVE,MULTILINE,DOTALL,UNICODE CASE, CANON EQ

    返回当前pattern 匹配的flag 参数

        int flags() 
    

    生成一个给定命名的Matcher对象

      Matcher matcher(CharSequence input) 
    

    编译指定 的正则表达 并且对于输入的字符串,已该正则表达式为模开展匹配,该方法适合于该正则表达式只会使用一次的情况, 也就只进行一次匹配工作, 这种情况不需要生成一个matcher实例

      static boolean matches(String text, String regex)
    
    
      static boolean matches(String text,Pattern pattern) 
    

    返回该pattern 对象所编译的正则表达式

      String pattern();
    

    将目标字符串按照pattern 里面所包含的正则表达式为模进行分割

       String[] split(CharSequence input) 
    

    作用同上 增加参数limit 目的在于要制定分割的段数, 比如limit = 2 那么目标字符串将根据正则表达式分割为两段

      String[] split(CharSequence input, int limit)
    

    一个正则表达式 其实是一段有特定意义的字符, 首先编译成一个 Pattern 类的实例,这个Pattern 对象使用matcher()方法来生成一个Matcher实例, 然后可以使用该实例以编译的正则表达式为基础对目标进行匹配工作, 多个matcher可以公用一个Pattern 对象

    Matcher类

    方法如下 :

    Matcher appendReplacement(StringBuffer sb, String replacement)
    

    将当前匹配子串替换为指定字符串, 并且将替换的子串以及上次匹配子串之后的字符串之后的字符串段添加到一个 StringBuffer 对象里

      StringBuffer appendTail(StringBuffer sb)
    

    将退后一次匹配工作后剩余的字符串添加到一个StringBuffer对象里

        int end();
    

    返回匹配的子串的最后一个字符在原目标字符串中的索引位置

      int end(int group)
    

    返回匹配模式例指定的组相配的子串最后一个字符的位置

      boolean find(); 
    

    在目标字符串中查找下一个匹配的子串

    boolean find(int start)
    

    重新设置matcher对象, 并且子在目标字符串里从指定的位置开始查找下一个匹配的子串,

        String group() 
    

    返回当前查找而获得的与组匹配的所有子串内容

        String group(int group) 
    

    返回当前查找而获得的与指定的组匹配的子串内容

         int groupCount() 
    

    返回当前查找所获得的匹配组的数量。

        boolean lookingAt() 
    

    检测目标字符串是否以匹配的子串起始。

        boolean matches() 
    

    尝试对整个目标字符展开匹配检测,也就是只有整个目标字符串完全匹配时才返回真值。

        Pattern pattern() 
    

    返回该Matcher对象的现有匹配模式,也就是对应的Pattern 对象。

        String replaceAll(String replacement) 
    

    将目标字符串里与既有模式相匹配的子串全部替换为指定的字符串。

        String replaceFirst(String replacement) 
    

    将目标字符串里第一个与既有模式相匹配的子串替换为指定的字符串。

        Matcher reset() 
    

    重设该Matcher对象。

        Matcher reset(CharSequence input) 
    

    重设该Matcher对象并且指定一个新的目标字符串。

        int start() 
    

    返回当前查找所获子串的开始字符在原目标字符串中的位置。

      int start(int group) 
    

    返回当前查找所获得的和指定组匹配的子串的第一个字符在原目标字符串中的位置。

    常用的正则表达式
    1 数字:^[0-9]*$
    2 n位的数字:^\d{n}$
    3 至少n位的数字:^\d{n,}$
    4 m-n位的数字:^\d{m,n}$
    5 零和非零开头的数字:^(0|[1-9][0-9]*)$
    6 非零开头的最多带两位小数的数字:^([1-9][0-9]*)+(.[0-9]{1,2})?$
    7 带1-2位小数的正数或负数:^(\-)?\d+(\.\d{1,2})?$
    8 正数、负数、和小数:^(\-|\+)?\d+(\.\d+)?$
    9 有两位小数的正实数:^[0-9]+(.[0-9]{2})?$
    10 有1~3位小数的正实数:^[0-9]+(.[0-9]{1,3})?$
    11 非零的正整数:^[1-9]\d*$ 或 ^([1-9][0-9]*){1,3}$ 或 ^\+?[1-9][0-9]*$
    12 非零的负整数:^\-[1-9][]0-9"*$ 或 ^-[1-9]\d*$
    13 非负整数:^\d+$ 或 ^[1-9]\d*|0$
    14 非正整数:^-[1-9]\d*|0$ 或 ^((-\d+)|(0+))$
    15 非负浮点数:^\d+(\.\d+)?$ 或 ^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$ 
    16 非正浮点数:^((-\d+(\.\d+)?)|(0+(\.0+)?))$ 或 ^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$
    17 正浮点数:^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ 或 ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9]  [0-9]*))$
    18 负浮点数:^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$ 或 ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$
    19 浮点数:^(-?\d+)(\.\d+)?$ 或 ^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$
    
    校验字符表达式
     1 汉字:^[\u4e00-\u9fa5]{0,}$
     2 英文和数字:^[A-Za-z0-9]+$ 或 ^[A-Za-z0-9]{4,40}$
     3 长度为3-20的所有字符:^.{3,20}$
     4 由26个英文字母组成的字符串:^[A-Za-z]+$
     5 由26个大写英文字母组成的字符串:^[A-Z]+$
     6 由26个小写英文字母组成的字符串:^[a-z]+$
     7 由数字和26个英文字母组成的字符串:^[A-Za-z0-9]+$
     8 由数字、26个英文字母或者下划线组成的字符串:^\w+$ 或 ^\w{3,20}$
     9 中文、英文、数字包括下划线:^[\u4E00-\u9FA5A-Za-z0-9_]+$
    10 中文、英文、数字但不包括下划线等符号:^[\u4E00-\u9FA5A-Za-z0-9]+$ 或 ^[\u4E00-\u9FA5A-Za-z0-9]{2,20}$
    11 可以输入含有^%&',;=?$\"等字符:[^%&',;=?$\x22]+
    12 禁止输入含有~的字符:[^~\x22]+
    
    特殊字符表达式
      1 Email地址:^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$
     2 域名:[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?
     3 InternetURL:[a-zA-z]+://[^\s]* 或 ^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$
     4 手机号码:^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$
     5 电话号码("XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX):^(\(\d{3,4}-)|\d{3.4}-)?\d{7,8}$ 
     6 国内电话号码(0511-4405222、021-87888822):\d{3}-\d{8}|\d{4}-\d{7}
     7 身份证号(15位、18位数字):^\d{15}|\d{18}$
     8 短身份证号码(数字、字母x结尾):^([0-9]){7,18}(x|X)?$ 或 ^\d{8,18}|[0-9x]{8,18}|[0-9X]{8,18}?$
     9 帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
    10 密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线):^[a-zA-Z]\w{5,17}$
    11 强密码(必须包含大小写字母和数字的组合,不能使用特殊字符,长度在8-10之间):^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$  
    12 日期格式:^\d{4}-\d{1,2}-\d{1,2}
    13 一年的12个月(01~09和1~12):^(0?[1-9]|1[0-2])$
    14 一个月的31天(01~09和1~31):^((0?[1-9])|((1|2)[0-9])|30|31)$ 
    15 钱的输入格式:
    16    1.有四种钱的表示形式我们可以接受:"10000.00" 和 "10,000.00", 和没有 "分" 的 "10000" 和 "10,000":^[1-9][0-9]*$ 
    17    2.这表示任意一个不以0开头的数字,但是,这也意味着一个字符"0"不通过,所以我们采用下面的形式:^(0|[1-9][0-9]*)$ 
    18    3.一个0或者一个不以0开头的数字.我们还可以允许开头有一个负号:^(0|-?[1-9][0-9]*)$ 
    19    4.这表示一个0或者一个可能为负的开头不为0的数字.让用户以0开头好了.把负号的也去掉,因为钱总不能是负的吧.下面我们要加的是说明可能的小数部分:^[0-9]+(.[0-9]+)?$ 
    20    5.必须说明的是,小数点后面至少应该有1位数,所以"10."是不通过的,但是 "10" 和 "10.2" 是通过的:^[0-9]+(.[0-9]{2})?$ 
    21    6.这样我们规定小数点后面必须有两位,如果你认为太苛刻了,可以这样:^[0-9]+(.[0-9]{1,2})?$ 
    22    7.这样就允许用户只写一位小数.下面我们该考虑数字中的逗号了,我们可以这样:^[0-9]{1,3}(,[0-9]{3})*(.[0-9]{1,2})?$ 
    23    8.1到3个数字,后面跟着任意个 逗号+3个数字,逗号成为可选,而不是必须:^([0-9]+|[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$ 
    24    备注:这就是最终结果了,别忘了"+"可以用"*"替代如果你觉得空字符串也可以接受的话(奇怪,为什么?)最后,别忘了在用函数时去掉去掉那个反斜杠,一般的错误都在这里
    25 xml文件:^([a-zA-Z]+-?)+[a-zA-Z0-9]+\\.[x|X][m|M][l|L]$
    26 中文字符的正则表达式:[\u4e00-\u9fa5]
    27 双字节字符:[^\x00-\xff]    (包括汉字在内,可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1))
    28 空白行的正则表达式:\n\s*\r    (可以用来删除空白行)
    29 HTML标记的正则表达式:<(\S*?)[^>]*>.*?</\1>|<.*? />    (网上流传的版本太糟糕,上面这个也仅仅能部分,对于复杂的嵌套标记依旧无能为力)
    30 首尾空白字符的正则表达式:^\s*|\s*$或(^\s*)|(\s*$)    (可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式)
    31 腾讯QQ号:[1-9][0-9]{4,}    (腾讯QQ号从10000开始)
    32 中国邮政编码:[1-9]\d{5}(?!\d)    (中国邮政编码为6位数字)
    33 IP地址:\d+\.\d+\.\d+\.\d+    (提取IP地址时有用)
    34 IP地址:((?:(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d))    (由@飞龙三少 提供,感谢共享)

    相关文章

      网友评论

          本文标题:java 正则表达

          本文链接:https://www.haomeiwen.com/subject/yyyhjxtx.html