标签:
正则表达式
import java.util.Scanner; public class RegexDemo01 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.println("请输入您的QQ号码:"); String str = sc.nextLine(); boolean f = queckQQ(str); System.out.println("result:"+f); } public static boolean queckQQ(String qq) { boolean flag = true; if (qq == null || qq.length() == 0) flag = false; if (qq.length() >= 5 && qq.length() <= 15){ if(!qq.startsWith("0")){ char[] ch = qq.toCharArray(); for(int i = 0; i < ch.length;i++){ char c = ch[i]; if (!Character.isDigit(c)){ flag = false; } } }else{ flag = false; } }else{ flag = false; } return flag; } }
import java.util.Scanner; public class RegexDemo02 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.println("请输入您的QQ号码:"); String str = sc.nextLine(); boolean f = queckQQ(str); System.out.println("result:"+f); } public static boolean queckQQ(String qq) { String regex = "[1-9][0-9]{4,14}"; boolean flag = qq.matches(regex); return flag; //return qq.matches("[1-9][0-9]{4,14}"); } }
X ? | X,一次或一次也没有 |
X* | X,零次或多次 |
X+ | X,一次或多次 |
X{n} | X,恰好 n 次 |
X{n,} | X,至少 n 次 |
X{n,m} | X,至少 n 次,但是不超过 m 次 |
public static boolean matches(String regex, CharSequence input)
编译给定正则表达式并尝试将给定输入与其匹配。
调用此便捷方法的形式
与表达式Pattern.matches(regex, input);
的行为完全相同。Pattern.compile(regex).matcher(input).matches()
如果要多次使用一种模式,编译一次后重用此模式比每次都调用此方法效率更高。
regex
- 要编译的表达式input
- 要匹配的字符序列PatternSyntaxException
- 如果表达式的语法无效import java.util.Scanner; public class RegexDemo03 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.println("请输入您的手机号码:"); String phone = sc.nextLine(); boolean f = queckTelPhone(phone); System.out.println("result:"+f); } public static boolean queckTelPhone(String phone) { String regex = "1[38]\\d{9}"; return phone.matches(regex); } }
举例2:校验邮箱。
import java.util.Scanner; /** * 定义邮箱的规则 * 1517806580@qq.com * liuyi@163.com * linqingxia@126.com * fengqingyang@sina.com.cn * fqy@itcast.cn */ public class RegexDemo04 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.println("请输入您的邮箱:"); String email = sc.nextLine(); boolean f = queckEmail(email); System.out.println("result:"+f); } public static boolean queckEmail(String email) { String regex = "\\w+@\\w{2,6}(\\.\\w{2,3})+"; return email.matches(regex); } }
public String[] split(CharSequence input, int limit)
此方法返回的数组包含输入序列的子字符串,由匹配此模式的另一子序列或输入序列的结尾终止。数组中子字符串的顺序与其在输入中出现的顺序相同。如果此模式与输入的任何子序列都不匹配,那么得到的数组仅包含一个元素,即字符串形式的输入序列。
limit 参数控制应用模式的次数,从而影响结果数组的长度。如果限制 n 大于零,那么模式至多应用 n> - 1 次,数组的长度不大于 n,并且数组的最后条目将包含除最后的匹配定界符之外的所有输入。如果 n 非正,那么将应用模式的次数不受限制,并且数组可以为任意长度。如果 n 为零,那么应用模式的次数不受限制,数组可以为任意长度,并且将丢弃尾部空字符串。
import java.util.Scanner; public class RegexDemo05 { public static void main(String[] args) { //定义一个年龄搜索范围 String ages = "18-24"; //定义规则 String regex = "-"; //调用方法 String[] strArray = ages.split(regex); //如何得到int类型的呢? int startAge = Integer.parseInt(strArray[0]); int endAge = Integer.parseInt(strArray[1]); //键盘录入年龄 Scanner sc = new Scanner(System.in); System.out.println("请输入你的年龄:"); int age = sc.nextInt(); if(age>=startAge && age<=endAge) { System.out.println("你就是我想找的"); }else { System.out.println("不符合我的要求,gun"); } } }
举例4:直接分割
public class RegexDemo06 { public static void main(String[] args) { // 定义一个字符串 String s1 = "aa,bb,cc"; // 直接分割 String[] str1Array = s1.split(","); for (int x = 0; x < str1Array.length; x++) { System.out.println(str1Array[x]); } System.out.println("---------------------"); String s2 = "aa.bb.cc"; String[] str2Array = s2.split("\\."); for (int x = 0; x < str2Array.length; x++) { System.out.println(str2Array[x]); } System.out.println("---------------------"); String s3 = "aa bb cc"; String[] str3Array = s3.split(" +"); for (int x = 0; x < str3Array.length; x++) { System.out.println(str3Array[x]); } System.out.println("---------------------"); //硬盘上的路径,我们应该用\\替代\ String s4 = "E:\\JavaSE\\day14\\avi"; String[] str4Array = s4.split("\\\\"); for (int x = 0; x < str4Array.length; x++) { System.out.println(str4Array[x]); } System.out.println("---------------------"); } }
import java.util.Arrays; public class RegexDemo07 { public static void main(String[] args) { String s = "91 27 46 38 50"; String[] strArray = s.split(" "); int[] arr = new int[strArray.length]; for (int x = 0; x < strArray.length; x++){ arr[x] = Integer.parseInt(strArray[x]); } Arrays.sort(arr); StringBuilder sb = new StringBuilder(); for(int x = 0; x < arr.length; x++){ sb.append(arr[x]).append(" "); } String result = sb.toString().trim(); System.out.println("result:"+result); } }
public class RegexDemo08 { public static void main(String[] args) { String s = "helloqq12345worldkh622112345678java"; String regex = "\\d"; String ss = "*"; String result = s.replaceAll(regex,ss); System.out.println("result:"+result); } }
import java.util.regex.Matcher; import java.util.regex.Pattern; public class RegexDemo09 { public static void main(String[] args) { // 模式和匹配器的典型调用顺序 // 把正则表达式编译成模式对象 Pattern p = Pattern.compile("a*b"); // 通过模式对象得到匹配器对象,这个时候需要的是被匹配的字符串 Matcher m = p.matcher("aaaaab"); // 调用匹配器对象的功能 boolean b = m.matches(); System.out.println(b); //以上是判断功能,太麻烦了,我们直接用字符串的方法做 String s = "aaaaab"; String regex = "a*b"; boolean bb = s.matches(regex); System.out.println(bb); } }
import java.util.regex.Matcher; import java.util.regex.Pattern; /** * Created by gao on 15-12-5. */ public class RegexDemo10 { public static void main(String[] args) { // 定义字符串 String s = "da jia ting wo shuo,jin tian yao xia yu,bu shang wan zi xi,gao xing bu?"; // 规则 \\b表示单词边界,边界不允许出现单词字符 String regex = "\\b\\w{3}\\b"; // 把规则编译成模式对象 Pattern p = Pattern.compile(regex); // 通过模式对象得到匹配器对象 Matcher m = p.matcher(s); // 调用匹配器对象的功能 // 通过find方法就是查找有没有满足条件的子串 // public boolean find() while (m.find()) { System.out.println(m.group()); } // 注意:一定要先find(),然后才能group() // IllegalStateException: No match found // String ss = m.group(); // System.out.println(ss); } }
标签:
原文地址:http://www.cnblogs.com/yangyquin/p/5022036.html