天天看點

黑馬程式員——java基礎:正規表達式

------- android教育訓練、java教育訓練、期待與您交流! ----------

1,正規表達式:符合一定規則的表達式。

作用:用于專門操作字元串。

特點:用于一些特定的符号來表示一些代碼操作。這樣就簡化書寫。

是以學習正規表達式,就是在學習一些特殊符号的使用。

好處:可以簡化對字元串的複雜操作。

弊端:符号定義越多,正則越長,閱讀性越差。

2,常用的正則

     \d  0-9的數字

    \D  非0-9的數字

    \w  a-zA-Z,0-9,下劃線

    \W  a-zA-Z,0-9,下劃線

    以上這些在使用的時候,需要使用\來轉義,因為我們是在字元串使用,要不然它就失去了它的含義了。

    [a-zA-Z]  a-zA-Z中間的任意一個

    [^a-zA-Z] 非a-zA-Z中間的任意一個

    [0-9]可以使用\d來替換使用

    ?  一次或一次也沒有

    +  一次或多次

    *  零次或多次

    {n}  恰好n次

    {n,}  至少n次

    {n,m} 至少n次但不超過m次

3,具體操作功能:

1,比對:String  matches方法。用規則比對整個字元串,隻要有一處不符合規則,就比對結束,傳回false。

2,切割:String split();

3,替換:String replaceAll(regex,str);如果regex中有定義組,可以在第二參數中通過$符号擷取正規表達式中的已有的組。

class  RegexDemo
{
	public static void main(String[] args) 
	{
		//demo();
		//System.out.println((char)11);
//		checkTel();

		//splitDemo("zhangsan.lisi.wangwu","\\.");
		//splitDemo("c:\\abc\\a.txt","\\\\");

		//splitDemo("erkktyqqquizzzzzo","(.)\\1+");//按照疊詞完成切割。為了可以讓規則的結果被重用
												//可以将規則封裝成一個組。用()完成。組的出現都有編号。
												//從1開始。 想要使用已有的組可以通過  \n(n就是組的編号)的形式來擷取。

		String str = "wer1389980000ty1234564uiod234345675f";//将字元串中的數組替換成#。
		
		//replaceAllDemo(str,"\\d{5,}","#");

		String str1 = "erkktyqqquizzzzzo";//将疊詞替換成$.  //将重疊的字元替換成單個字母。zzzz->z
		replaceAllDemo(str1,"(.)\\1+","$1");

		
	}

	public static void replaceAllDemo(String str,String reg,String newStr)
	{
		str = str.replaceAll(reg,newStr);

		System.out.println(str);
	}



	public static void splitDemo(String str,String reg)
           
{
		
		//String reg = " +";//按照多個空格來進行切割
		String[] arr = str.split(reg);  
		System.out.println(arr.length);
		for(String s : arr)
		{
			System.out.println(s);
		}
	}
           

比對

手機号段隻有 13xxx 15xxx 18xxxx

public static void checkTel()
	{
		String tel = "16900001111";
		String telReg = "1[358]\\d{9}";
		System.out.println(tel.matches(telReg));
	}

	public static void demo()
	{
		String str = "b23a23456789";

		String reg = "[a-zA-Z]\\d*";

		boolean b= str.matches(reg);
		System.out.println(b);
	}
	public static void checkQQ()
	{
		String qq = "123a454";

		String regex = "[1-9]\\d{4,14}";

		boolean flag = qq.matches(regex);
		if(flag)
			System.out.println(qq+"...is ok");
		else
			System.out.println(qq+"... 不合法");

	}
           

對QQ号碼進行校驗

要求:5~15  0不能開頭,隻能是數字

這種方式,使用了String類中的方法,進行組合完成了需求。但是代碼過于複雜。

public static void checkQQ_1()
	{
		String qq = "1882345a0";

		int len = qq.length();

		if(len>=5 && len<=15)
		{
			if(!qq.startsWith("0"))//Integer.parseInt("12a");NumberFormatException
			{
				try
				{
					long l = Long.parseLong(qq);
					System.out.println("qq:"+l);
				}
				catch (NumberFormatException e)
				{
					System.out.println("出現非法字元.......");
				}
				
				/*
				char[] arr = qq.toCharArray();//123a4
				boolean flag = true;
				for(int x=0;x<arr.length; x++)
				{
					if(!(arr[x]>='0' && arr[x]<='9'))
					{
						flag = false;
						break;
					}
				}
				if(flag)
				{
					System.out.println("qq:"+qq);
				}
				else
				{
					System.out.println("出現非法字元");	
				}
				*/
			}
			else
			{
				System.out.println("不可以0開頭");

			}
		}
		else
		{
			System.out.println("長度錯誤");
		}
	}
}
           

正規表達式的第四個功能。

4,擷取:将字元串中的符合規則的子串取出。

操作步驟:

1,将正規表達式封裝成對象。

2,讓正則對象和要操作的字元串相關聯。

3,關聯後,擷取正則比對引擎。

4,通過引擎對符合規則的子串進行操作,比如取出。

import java.util.regex.*;

class RegexDemo2 
{
	public static void main(String[] args) 
	{
		getDemo();
	}
	public static void getDemo()
	{
		String str = "ming tian jiu yao fang jia le ,da jia。";
		System.out.println(str);
		String reg = "\\b[a-z]{4}\\b";

		//将規則封裝成對象。
		Pattern p = Pattern.compile(reg);

		//讓正則對象和要作用的字元串相關聯。擷取比對器對象。
		Matcher m  = p.matcher(str);

		//System.out.println(m.matches());//其實String類中的matches方法。用的就是Pattern和Matcher對象來完成的。
										//隻不過被String的方法封裝後,用起來較為簡單。但是功能卻單一。

//		boolean b = m.find();//将規則作用到字元串上,并進行符合規則的子串查找。
//		System.out.println(b);
//		System.out.println(m.group());//用于擷取比對後結果。
		
		
		//System.out.println("matches:"+m.matches());
		while(m.find())
		{
			System.out.println(m.group());
			System.out.println(m.start()+"...."+m.end());
		}
	}
}