我是靠谱客的博主 能干花卷,最近开发中收集的这篇文章主要介绍JavaSE|正则表达式规则应用案例,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

JavaSE|正则表达式

  • 规则
  • 应用
    • 判断
    • 分割
    • 替换
    • 获取
  • 案例

符合一定规则的字符串。

规则

应用

判断

public boolean matches(String regex) String 类的方法
告知此字符串是否匹配给定的正则表达式。

分割

public String[] split(String regex) String 类的方法
根据给定正则表达式的匹配拆分此字符串。

替换

public String replaceAll(String regex,String replacement) String 类的方法
使用给定的 replacement 替换此字符串所有匹配给定的正则表达式的子字符串。


// 定义一个字符串
String s = "helloqq12345worldkh622112345678java";
String regex = "\d";
String ss = "*";
String result = s.replaceAll(regex, ss);
System.out.println(result); //helloqq*****worldkh************java

获取

Pattern类
正则表达式的编译表示形式。
指定为字符串的正则表达式必须首先被编译为此类的实例。然后,可将得到的模式用于创建 Matcher 对象,依照正则表达式,该对象可以与任意字符序列匹配。执行匹配所涉及的所有状态都驻留在匹配器中,所以多个匹配器可以共享同一模式。

因此,典型的调用顺序是:
Pattern p = Pattern.compile(“a*b”);
Matcher m = p.matcher(“aaaaab”);
boolean b = m.matches();

Matcher类
通过调用模式的 matcher 方法从模式创建匹配器。创建匹配器后,可以使用它执行三种不同的匹配操作:

  • matches 方法尝试将整个输入序列与该模式匹配。
  • lookingAt 尝试将输入序列从头开始与该模式匹配。
  • find 方法扫描输入序列以查找与该模式匹配的下一个子序列。

boolean find()
尝试查找与该模式匹配的输入序列的下一个子序列。
String group()
返回由以前匹配操作所匹配的输入子序列。

一定要先find()才能group(),否则会报错。


// 定义字符串
String s = "da jia ting wo shuo,jin tian yao xia yu,bu shang wan zi xi,gao xing bu?";
// 规则
String regex = "\b\w{3}\b";
// 把规则编译成模式对象
Pattern p = Pattern.compile(regex);
// 通过模式对象得到匹配器对象
Matcher m = p.matcher(s);
while (m.find()) {
System.out.println(m.group());
}
// 注意:一定要先find(),然后才能group()
// IllegalStateException: No match found
// String ss = m.group();
// System.out.println(ss);

案例

  1. 判断电话号码和邮箱
  2. 按照不同的规则分割数据
  3. 把论坛中的数字替换为*
  4. 获取字符中由3个字符组成的单词

最后

以上就是能干花卷为你收集整理的JavaSE|正则表达式规则应用案例的全部内容,希望文章能够帮你解决JavaSE|正则表达式规则应用案例所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(57)

评论列表共有 0 条评论

立即
投稿
返回
顶部