Java正则表达式

简介:

 正则表达式通常处理方式:

 
  1. Pattern p = Pattern.compile("a*b"); 
  2.         Matcher m = p.matcher("aaaaab"); 
  3.         boolean b = m.matches(); 

 或者:System.out.println("abc".matches("..."));//String类中有match()方法

正则表达式规则如下,更多请参考java的Pattern类的详细介绍。

 
  1. 构造 匹配  
  2.    
  3. 字符  
  4. x 字符 x  
  5. \\ 反斜线字符  
  6. \0n 带有八进制值 0 的字符 n (0 <= n <= 7)  
  7. \0nn 带有八进制值 0 的字符 nn (0 <= n <= 7)  
  8. \0mnn 带有八进制值 0 的字符 mnn(0 <= m <= 3、0 <= n <= 7)  
  9. \xhh 带有十六进制值 0x 的字符 hh  
  10. \uhhhh 带有十六进制值 0x 的字符 hhhh  
  11. \t 制表符 ('\u0009')  
  12. \n 新行(换行)符 ('\u000A')  
  13. \r 回车符 ('\u000D')  
  14. \f 换页符 ('\u000C')  
  15. \a 报警 (bell) 符 ('\u0007')  
  16. \e 转义符 ('\u001B')  
  17. \cx 对应于 x 的控制符  
  18.    
  19. 字符类  
  20. [abc] a、b 或 c(简单类) 【注意】非"abc",而是"[abc]"
  21. [^abc] 任何字符,除了 a、b 或 c(否定)  
  22. [a-zA-Z] a 到 z 或 A 到 Z,两头的字母包括在内(范围)  
  23. [a-d[m-p]] a 到 d 或 m 到 p:[a-dm-p](并集)  
  24. [a-z&&[def]] d、e 或 f(交集)  
  25. [a-z&&[^bc]] a 到 z,除了 b 和 c:[ad-z](减去)  
  26. [a-z&&[^m-p]] a 到 z,而非 m 到 p:[a-lq-z](减去)  
  27.    
  28. 预定义字符类  
  29. . 任何字符(与行结束符可能匹配也可能不匹配)  
  30. \d 数字:[0-9]  
  31. \D 非数字: [^0-9]  
  32. \s 空白字符:[ \t\n\x0B\f\r]  
  33. \S 非空白字符:[^\s]  
  34. \w 单词字符:[a-zA-Z_0-9]  
  35. \W 非单词字符:[^\w]  
  36.    
  37. POSIX 字符类(仅 US-ASCII)  
  38. \p{Lower} 小写字母字符:[a-z]  
  39. \p{Upper} 大写字母字符:[A-Z]  
  40. \p{ASCII} 所有 ASCII:[\x00-\x7F]  
  41. \p{Alpha} 字母字符:[\p{Lower}\p{Upper}]  
  42. \p{Digit} 十进制数字:[0-9]  
  43. \p{Alnum} 字母数字字符:[\p{Alpha}\p{Digit}]  
  44. \p{Punct} 标点符号:!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~  
  45. \p{Graph} 可见字符:[\p{Alnum}\p{Punct}]  
  46. \p{Print} 可打印字符:[\p{Graph}\x20]  
  47. \p{Blank} 空格或制表符:[ \t]  
  48. \p{Cntrl} 控制字符:[\x00-\x1F\x7F]  
  49. \p{XDigit} 十六进制数字:[0-9a-fA-F]  
  50. \p{Space} 空白字符:[ \t\n\x0B\f\r]  
  51.    
  52. java.lang.Character 类(简单的 java 字符类型)  
  53. \p{javaLowerCase} 等效于 java.lang.Character.isLowerCase()  
  54. \p{javaUpperCase} 等效于 java.lang.Character.isUpperCase()  
  55. \p{javaWhitespace} 等效于 java.lang.Character.isWhitespace()  
  56. \p{javaMirrored} 等效于 java.lang.Character.isMirrored()  
  57.    
  58. Unicode 块和类别的类  
  59. \p{InGreek} Greek 块(简单块)中的字符  
  60. \p{Lu} 大写字母(简单类别)  
  61. \p{Sc} 货币符号  
  62. \P{InGreek} 所有字符,Greek 块中的除外(否定)  
  63. [\p{L}&&[^\p{Lu}]]  所有字母,大写字母除外(减去)  
  64.    
  65. 边界匹配器  
  66. ^ 行的开头  
  67. $ 行的结尾  
  68. \b 单词边界  
  69. \B 非单词边界  
  70. \A 输入的开头  
  71. \G 上一个匹配的结尾  
  72. \Z 输入的结尾,仅用于最后的结束符(如果有的话)  
  73. \z 输入的结尾  
  74.    
  75. Greedy 数量词  
  76. X? X,一次或一次也没有  
  77. X* X,零次或多次  
  78. X+ X,一次或多次  
  79. X{n} X,恰好 n 次  
  80. X{n,} X,至少 n 次  
  81. X{n,m} X,至少 n 次,但是不超过 m 次  
  82.    
  83. Reluctant 数量词  
  84. X?? X,一次或一次也没有  
  85. X*? X,零次或多次  
  86. X+? X,一次或多次  
  87. X{n}? X,恰好 n 次  
  88. X{n,}? X,至少 n 次  
  89. X{n,m}? X,至少 n 次,但是不超过 m 次  
  90.    
  91. Possessive 数量词  
  92. X?+ X,一次或一次也没有  
  93. X*+ X,零次或多次  
  94. X++ X,一次或多次  
  95. X{n}+ X,恰好 n 次  
  96. X{n,}+ X,至少 n 次  
  97. X{n,m}+ X,至少 n 次,但是不超过 m 次  
  98.    
  99. Logical 运算符  
  100. XY X 后跟 Y  
  101. X|Y X 或 Y  
  102. (X) X,作为捕获组  
  103.    
  104. Back 引用  
  105. \n 任何匹配的 nth 捕获组  
  106.    
  107. 引用  
  108. \ Nothing,但是引用以下字符  
  109. \Q Nothing,但是引用所有字符,直到 \E  
  110. \E Nothing,但是结束从 \Q 开始的引用  
  111.    
  112. 特殊构造(非捕获)  
  113. (?:X) X,作为非捕获组  
  114. (?idmsux-idmsux)  Nothing,但是将匹配标志i d m s u x on - off  
  115. (?idmsux-idmsux:X)   X,作为带有给定标志 i d m s u x on - off  
  116. 的非捕获组  (?=X) X,通过零宽度的正 lookahead  
  117. (?!X) X,通过零宽度的负 lookahead  
  118. (?<=X) X,通过零宽度的正 lookbehind  
  119. (?<!X) X,通过零宽度的负 lookbehind  
  120. (?>X) X,作为独立的非捕获组  

 场景1:将所有数字用'-'替换

 
  1. String s = "abc123def456hijas2kj23jl1"
  2.     String dest = s.replaceAll("\\d""-"); 
  3.     System.out.println(dest); 

 场景2:判断是否是电子邮箱

 
  1. String s = "tianya@sina.com"
  2.         System.out.println(s.matches(".+@.+\\..+")); 

【注】\\.代表'.',表示真正的‘点’号,否则会代表‘任意字符’

 场景3:

邮箱验证: String regEmail = "^(?:\\w+\\.{1})*\\w+@(\\w+\\.)*\\w+$"

ip 地址的验证: String reIp = "\\b((\\d{1,2}|1\\d\\d|2[0-4]\\d|25[0-5])(\\b|\\.)){4}";  

验证日期: String reDate = "(?:[1-9]|0[1-9]|[12]\\d|3[0-1])(\\/|\\-)(?:[1-9]|0[1-9]|1[0-2])(\\/|\\-)(?:19|20\\d\\d)";

验证信用卡号:String reCard = "^(4\\d{12}(?:\\d{3})?)$";

测试:

 
  1. String email = "qing.qingbyqing@gmail.vip.com";//邮箱测试   
  2.        FormValid.isValidEmail(email);   
  3.         String strIp="1.10.111.255";//IP地址测试   
  4.        FormValid.isValidIp(strIp);   
  5.            
  6.         String sDate="03/03/1911";    
  7.         FormValid.isValidDate(sDate);//日期测试   
  8.          
  9.  
  10.       String strNum = "4432123456788881";   
  11.       w(FormValid.isValidCard(strNum));//信用卡测试   

 

 本文转自 tianya23 51CTO博客,原文链接:http://blog.51cto.com/tianya23/673756,如需转载请自行联系原作者

相关文章
|
29天前
|
Java
【Java】如果一个集合中类型是String如何使用拉姆达表达式 进行Bigdecimal类型计算?
【Java】如果一个集合中类型是String如何使用拉姆达表达式 进行Bigdecimal类型计算?
25 0
|
16天前
|
XML 数据可视化 前端开发
java正则表达式
java正则表达式
|
1天前
|
Java 程序员 编译器
JavaSE&Java8 Lambda 表达式
JavaSE&Java8 Lambda 表达式
|
4天前
|
并行计算 Java 编译器
Java Lambda表达式简介
Java Lambda表达式简介
11 0
|
6天前
|
Java 开发者
探索 Java 的函数式接口和 Lambda 表达式
【4月更文挑战第19天】Java 中的函数式接口和 Lambda 表达式提供了简洁、灵活的编程方式。函数式接口有且仅有一个抽象方法,用于与 Lambda(一种匿名函数语法)配合,简化代码并增强可读性。Lambda 表达式的优点在于其简洁性和灵活性,常用于事件处理、过滤和排序等场景。使用时注意兼容性和变量作用域,它们能提高代码效率和可维护性。
|
9天前
|
分布式计算 Java API
Java 8新特性之Lambda表达式与Stream API
【4月更文挑战第16天】本文将介绍Java 8中的两个重要新特性:Lambda表达式和Stream API。Lambda表达式是Java 8中引入的一种新的编程语法,它允许我们将函数作为参数传递给其他方法,从而使代码更加简洁、易读。Stream API是Java 8中引入的一种新的数据处理方式,它允许我们以声明式的方式处理数据,从而使代码更加简洁、高效。本文将通过实例代码详细讲解这两个新特性的使用方法和优势。
|
12天前
|
Java
Java 14 强势登场:Switch 表达式的进化之路
Java 14 强势登场:Switch 表达式的进化之路
16 0
|
15天前
|
Java 开发者
Java中的Lambda表达式:简洁、灵活的编程利器
在现代软件开发中,编写简洁、高效的代码是至关重要的。Java中的Lambda表达式为开发者提供了一种简洁、灵活的编程方式,使得代码更具可读性和可维护性。本文将探讨Lambda表达式的基本概念、语法结构以及在实际项目中的应用,以帮助读者更好地理解和运用这一强大的编程工具。
6 0
|
16天前
|
存储 Java API
java8新特性 lambda表达式、Stream、Optional
java8新特性 lambda表达式、Stream、Optional
|
29天前
|
Java API
Java中的Lambda表达式和函数式编程
传统的Java编程方式在处理一些简单的逻辑时显得繁琐,而Lambda表达式的引入为我们提供了一种更加简洁、灵活的编程方式。本文将介绍Lambda表达式和函数式编程在Java中的应用以及其与传统编程方式的对比,帮助读者更好地理解并运用这一特性。
7 0