利用正则表达式进行校验

字符描述:

  ^符号匹配字符串的开头。
         例如:^abc 与"abc  xyz"匹配,而不与"xyz  abc"匹配。

  $符号匹配字符串的结尾。
         例如:abc$ 与"xyz  abc"匹配,而不与"abc  xyz"匹配。
         注意:如果同时使用^符号和$符号,将进行精确匹配。例如:^abc$ 只与"abc"匹配。 

  *符号匹配0个或多个前面的字符。
         例如:ab* 可以匹配"ab"、"abb"、"abbb"等。

  +符号匹配至少一个前面的字符。
         例如:ab+ 可以匹配"abb"、"abbb"等,但不匹配"ab"。 

  ?符号匹配0个或1个前面的字符。
         例如:ab?c? 可以且只能匹配"abc"、"abbc"、"abcc"和"abbcc"。

  .符号匹配除换行符以外的任何字符。
         例如:(.)+ 匹配除换行符以外的所有字符串。

  x|y匹配"x"或"y"。
         例如:abc|xyz 可匹配  "abc"或  "xyz",而"ab(c|x)yz"匹配  "abcyz"和"abxyz"。

  {n}匹配恰好n次(n为非负整数)前面的字符。
         例如:a{2} 可以匹配"aa",但不匹配"a"。

  {n,}匹配至少n次(n为非负整数)前面的字符。
         例如:a{3,} 匹配"aaa"、"aaaa"等,但不匹配"a"和"aa"。
         注意:a{1,}等价于a+;a{0,}等价于a*。

  {m,n}匹配至少m个,至多n个前面的字符。
         例如:a{1,3} 只匹配"a"、"aa"和"aaa"。
         注意:a{0,1}等价于a?

  [xyz]表示一个字符集,匹配括号中字符的其中之一。
         例如:[abc] 匹配"a"、"b"和"c"。

  [^xyz]表示一个否定的字符集。匹配不在此括号中的任何字符。
         例如:[^abc] 可以匹配除"a"、"b"和"c"之外的任何字符。

  [a-z]表示某个范围内的字符,匹配指定区间内的任何字符。
         例如:[a-z] 匹配从"a"到"z"之间的任何一个小写字母字符。

  [^m-n]表示某个范围之外的字符,匹配不在指定范围内的字符。
         例如:[m-n] 匹配除从"m"到"n"之间的任何字符。

  /符号是转义操作符。
         例如:/n 换行符
               /f 分页符
               /r 回车
               /t 制表符
               /v 垂直制表符 
               // 匹配"/"
               // 匹配"/"
               /s 任何白字符,包括空格、制表符、分页符等。等价于"[  /f/n/r/t/v]"
               /S 任何非空白的字符。等价于"^/f/n/r/t/v]"
               /w 任何单词字符,包括字母和下划线。等价于"[A-Za-z0-9_]"
               /W 任何非单词字符。等价于"[^A-Za-z0-9_]"

  /b匹配单词的结尾。
         例如:ve/b 匹配单词"love"等,但不匹配"very"、"even"等。

  /B匹配单词的开头。
         例如:ve/B 匹配单词"very"等,但不匹配"love"等。

  /d匹配一个数字字符,等价于[0-9]。
         例如:abc/dxyz 匹配"abc2xyz"、"abc4xyz"等,但不匹配"abcaxyz"、"abc-xyz"等。

  /D匹配一个非数字字符,等价于[^0-9]。
         例如:abc/Dxyz 匹配"abcaxyz"、"abc-xyz"等,但不匹配"abc2xyz"、"abc4xyz"等。

  /NUM匹配NUM个(其中NUM为一个正整数),引用回到记住的匹配。
         例如:(.)/1 匹配两个连续相同的字符。 

  /oNUM匹配n(其中n为一个小于256的八进制换码值)。
         例如:/o011 匹配制表符。
   
    /xNUM匹配NUM(其中NUM为一个小于256的十六进制换码值)。
         例如:/x41 匹配字符"A"。


以下是对正则表达式的简单应用:

1. 邮政编码

 boolean checkPostcode()
 {
   Pattern p=Pattern.compile("[0-9]{6}");
   Matcher m=p.matcher(inputStr);
   if (!m.matches())
   {
     System.out.println("****邮政编码格式不符!*****");
     return false;
   }
   return true;
 }

java.util.regex中有两个类:Pattern和Matcher。
Pattern为模板,Matcher为被匹配者。
关于上面的程序可以参考Java的API中Pattern和Matcher类的说明。

介绍一下“[0-9]{6}”的意思:
[]中括号指定允许匹配的字符,一个[]只能允许匹配单个字符。0-9表示0到9之间的任意数字,同样A-Z就表示A到Z之间的任意字母,连接符-的意思相信你已经掌握了。{}大括号表示匹配次数,这里就表示匹配6次,即必须有6个数字。

2.EMAIL

 boolean checkEmail()
 {
    Pattern p=Pattern.compile("[0-9A-Za-z]+@([0-9a-zA-Z]+.){1,2}(com|net|cn|com.cn)");
    Matcher m=p.matcher(inputStr);
    if(!m.matches())
    {
      System.out.println("****电子邮件格式不符!*****");
      return false;
    }
    return true;
 }

这里给出匹配的表达式:
“[0-9A-Za-z]+@([0-9a-zA-Z]+.){1,2}(com|net|cn|com.cn)”。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值