欢迎访问悦橙教程(wld5.com),关注java教程。悦橙教程  java问答|  每日更新
页面导航 : > > > 文章正文

JavaSE|正则表达式,

来源: javaer 分享于  点击 6056 次 点评:184

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);

案例

相关文章

    暂无相关文章

用户点评