Java正则表达式

正则表达式可以简化对字符串的复杂操作。

一、匹配

import java.util.Scanner;
/**/
public class check {
	
	
	public static void main(String[] args) {
		Scanner input = new Scanner(System.in);
		String x = input.nextLine();
		checkTel(x);
	//	checkQQ(x);
		input.close();
	}
	/**
	 * 手机号码只有 13xxx  15xxx 18xxx 11位
	 * @param tel
	 */
	public static void checkTel(String tel){
		String telReg = "1[358]\\d{9}";
		System.out.println(tel.matches(telReg));
	}
	/**
	 * qq 5~15 0不能开头,只能是数字
	 * @param qq
	 */
	public static void checkQQ(String qq){
	//	String regex = "[1-9][0-9]{4,14}";
		String regex = "[1-9]\\d{4,14}";
	
		if(qq.matches(regex)){
			System.out.println(qq+"is ok.");
		}
		else{
			System.out.println(qq+"is not ok.");
		}
	}

}

二、获取

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class Get {


	public static void main(String[] args) {
		getDemo();
	}


	private static void getDemo() {
		String str = "ming tian jiu yao fang jia le ,da jia.";
		// \\b是单词边界
		String reg = "\\b[a-z]{4}\\b";
		Pattern p = Pattern.compile(reg);
		Matcher m = p.matcher(str);
		while(m.find()){
			System.out.println(m.group());
			//System.out.println(m.start()+"..."+m.end());
		}
	}


}

三、分割

public class split {

	public static void main(String[] args) {
		splitDemo();
	}

	private static void splitDemo() {
//		String str = "zahngsan,lisi,wangwu";
//		String reg = ",";
//		String str = "zahngsan   lisi   wangwu";
//              String reg = " +";
//		String str = "zahngsan.lisi.wangwu";
//		String reg = "\\."; 
//		\.代表正则表达式的普通的. 再转义\\.
//		String str = "c:\\abc\\a.txt";
//		String reg = "\\\\";
		String str = "erkktyqquizzzzzo";//按照叠词完成切割
		//可以将规则封装成一个组,用()完成。组的出线都有编号。
		//从1开始。想要使用已有的组可以通过 \n(n为组的编号)的形式来获取
		String reg = "(.)\\1+";
		String[] arr = str.split(reg);
		System.out.println(arr.length);
		for(String s : arr){
			System.out.println(s);
		}
	}

}

四、替换

public class ReplicAll {

	public static void main(String[] args) {
		String str = "wer1389980000ty1234564uiod23434234f44";
		//将字符串中5个以上的数字替换成#
		replaceAllDemo(str,"\\d{5,}","#");
		String str1 = "erkktyqquizzzzzo";
		//将叠词替换成&
		replaceAllDemo(str1, "(.)\\1+", "&");
		String str2 = "erkktyqquizzzzzo";
		//将重叠的字符替换成单个字母zzzz->z
		replaceAllDemo(str2, "(.)\\1+", "$1");
		
	}
	
	public static void replaceAllDemo(String str,
			String reg,String newStr){
		str = str.replaceAll(reg, newStr);
				System.out.println(str);
	}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值