.  any character

\d  A digit 0-9

\D  a non-digit [^0-9]

\s  a whitespace character, 空白字符

\S  a non-whitespace character

\w  a word character   [a-zA-Z0-9]

\W  a non-word character

X规范:

X:必须出现一次

X?, 0,1

X*, 0或者多次

X+, 1, n

X{n}, 必须出现n次

X{n,m}, 必须出现n~m次

X{n,}, 必须出现n次以上

XY, X后跟着Y规范

X|Y, X或Y规范

(X) 捕捉组规范

String str="1983-07-27"
String pat="\\d{4}-\\d{2}-\\d{2}";
if(Pattern.compile(pat).matcher(str).matches())
{
System.out.println("日期格式合法");
}

String的三个方法是支持正则的 matches, replaceAll,split

字符串拆分, 替换, 验证:

import java.util.regex.Pattern ;
import java.util.regex.Matcher ;
public class RegexDemo05{
public static void main(String args[]){
String str1 = "A1B22C333D4444E55555F".replaceAll("\\d+","_") ; //replaceAll
boolean temp = "1983-07-27".matches("\\d{4}-\\d{2}-\\d{2}") ; //matches
String s[] = "A1B22C333D4444E55555F".split("\\d+") ; //split
System.out.println("字符串替换操作:" + str1) ;
System.out.println("字符串验证:" + temp) ;
System.out.print("字符串的拆分:") ;
for(int x=0;x<s.length;x++){
System.out.print(s[x] + "\t") ;
}
}
};

注意拆分 |

import java.util.regex.Pattern ;
import java.util.regex.Matcher ;
public class RegexDemo07{
public static void main(String args[]){
String info = "LXH:98|MLDN:90|LI:100" ; // 定义一个字符串
// 拆分的形式:
/*
LXH --> 98
MLDN --> 90
LI --> 100
*/
String s[] = info.split("\\|") ;
System.out.println("字符串的拆分:") ;
for(int x=0;x<s.length;x++){
String s2[] = s[x].split(":") ;
System.out.println(s2[0] + "\t" + s2[1]) ;
}
}
};

  

  

  

package DAO;

import java.util.regex.Matcher;
import java.util.regex.Pattern; public class TestReg {
public static void main(String[] args) throws Exception{
/*System.out.println("abc".matches("...")); //true ctrl+shift+/ 注释
System.out.println("a898938593a".replaceAll("\\d","-")); //a---------a
Pattern p = Pattern.compile("[a-z]{3}"); //匹配具有3个字符的字符串
Matcher m = p.matcher("abc");
System.out.println(m.matches()); //true
*/ //初步认识 . * + ?, meta characters
/*p("a".matches(".")); // true
p("aa".matches("aa")); // true
p("aaaa".matches("a*")); // true 0或者n
p("aaaa".matches("a+")); // true 1或者n
p("aaaa".matches("a?")); // false 0或者1
p("".matches("a*")); // true 0或者n
p("".matches("a+")); // true 1或者n
p("".matches("a?")); // true 0或者1
p("215454545454545".matches("\\d{3,100}")); // true 3~100个
p("192.168.000.111".matches("\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}")); //true
p("192".matches("[0-2][0-9][0-9]")); //true
*/
//范围
/*p("a".matches("[abc]")); // true []取出一个字符
p("a".matches("[^abc]")); // false []取出一个字符
p("A".matches("[a-zA-Z]")); // true []取出一个字符
p("A".matches("[a-z]|[A-Z]")); // true []取出一个字符
p("A".matches("[a-z[A-Z]]")); // true []取出一个字符
p("R".matches("[A-Z&&|[RFG]]")); // true []取出一个字符
*/
//认识 \s \w \d
/*p(" \n\r\t".matches("\\s{4}")); //true 4个空白字符
p(" ".matches("S")); //false S代表非空白字符
p("a_8".matches("\\w{3}")); //true
p("abc888&^%".matches("[a-z]{1,3}\\d+[&^$%]+")); //true 1-3个字母, 1或n个数字, [&^$%]里任意1或n个
p("\\".matches("\\\\")); //正则表达式里 2个\\只代表一个转义字符
*/ //POSIX Style
//p("a".matches("\\p{Lower}")); //boundary
/*p("hello sir".matches("^h.*")); //true
p("hello sir".matches(".*ir$")); //true
p("hello sir".matches("^h[a-z]{1,3}o\\b.*")); //true
p("hellosir".matches("^h[a-z]{1,3}o\\b.*")); //true \b是空格, 换行等单词边界
*/ //white lines 空白行
//p(" \n".matches("^[\\s&&[^\\n]]*\\n$")); //true 开头是空白符, 而且不是回车, 0或n次, 后面紧跟着换行符 //practice
/*p("aaa 8888c".matches(".*\\d{4}.")); //true 0或n个字母, 4位数字, 然后有一个字母
p("aaa 8888c".matches(".*\\b\\d{4}.")); //true 0或n个字母, 4位数字前面有个单词边界, 然后有一个字母
p("aaa8888c".matches(".*\\d{4}.")); //true 0或n个字母, 4位数字, 然后有一个字母
p("aaa8888c".matches(".*\\b\\d{4}.")); //false 0或n个字母, 4位数字前面没有单词边界, 然后有一个字母
*/ //email
//p("adjkfjdksjfdksfjd@djfkjdkjsfd.com".matches("[\\w[.-]]+@[\\w[.-]]+\\.[\\w]+")); //true //matches find lookingAt start end matches每次找整个串, find找字串, lookingAt每次都从头找
/*Pattern p = Pattern.compile("\\d{3,5}");
String s = "123-34345-234-00";
Matcher m = p.matcher(s);
p(m.matches()); //把123-给吃了, 所以要reset以下. 否则, 如果不reset的话, 只有2个true 34345 234
m.reset(); //为了把matches吃掉的字符恢复
p(m.find()); //true 找一个匹配的字串 123
p(m.start()+"-"+m.end()); //0-3
p(m.find()); //true 找一个匹配的字串 34345
p(m.start()+"-"+m.end()); //4-9
p(m.find());//true找一个匹配的字串234
p(m.start()+"-"+m.end()); //10-13
p(m.find()); // false 00
p(m.lookingAt()); //true 只从head开始找, 所以是123
p(m.lookingAt()); //true 只从head开始找, 所以是123
p(m.lookingAt()); //true 只从head开始找, 所以是123
p(m.lookingAt()); //true 只从head开始找, 所以是123
*/ //replacement
Pattern p = Pattern.compile("java",Pattern.CASE_INSENSITIVE);
Matcher m = p.matcher("java Java JAVa JaVa IloveJAVA you hateJava");
StringBuffer buf = new StringBuffer();
int i=0;
/*while(m.find()){
p(m.group()); //列出所有java字样的
}
*/
while(m.find()){
i++;
if(i%2==0){
m.appendReplacement(buf, "java"); //偶数都是java
}
else{
m.appendReplacement(buf, "JAVA");//奇数都是JAVA
} }
m.appendTail(buf);
p(buf); //列出所有java字样的 }
public static void p(Object o){
System.out.println(o);
}
}

  

JAVA基础--正则表达式的更多相关文章

  1. Java基础-正则表达式(Regular Expression)语法规则简介

    Java基础-正则表达式(Regular Expression)语法规则简介 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.正则表达式的概念 正则表达式(Regular Exp ...

  2. Java基础——正则表达式

    一.什么是正则表达式 正则表达式,又称规则表达式.(英语:Regular Expression,在代码中常简写为regex.regexp或RE),计算机科学的一个概念.正则表通常被用来检索.替换那些符 ...

  3. Java基础--正则表达式的规则

    注意:正则表达式只关注格式是否正确,不关注内容是否有效. 一.字符集合, []表示一个字符. 1.[abc] :指a,b,c中的任意一个字符. 2.[^abc]:指除了a,b,c外的任意字符. 3.[ ...

  4. 二十八、Java基础--------正则表达式

    在对字符串进行处理时一方面可以利用String对象的一些处理方法另一方面可以利用正则表达式,但是一般情况下用String对象方法进行处理起来会相对麻烦一些而正则表达式可以很方便的解决问题.为了更好的学 ...

  5. java基础---->java中正则表达式二

    跟正则表达式相关的类有:Pattern.Matcher和String.今天我们就开始Java中正则表达式的学习. Pattern和Matcher的理解 一.正则表达式的使用方法 一般推荐使用的方式如下 ...

  6. 黑马程序员:Java基础总结----正则表达式

    黑马程序员:Java基础总结 正则表达式   ASP.Net+Android+IO开发 . .Net培训 .期待与您交流! 正则表达式 import  java.util.regex.*; 符合一定规 ...

  7. Java基础七-正则表达式

    Java基础七-正则表达式 一.定义: 特定的符号的组合 二.作用: 用于操作字符串数据 三.优缺点 简化代码,但是阅读性差 四.引入 4.1 问题 判断一个号码是否是QQ号? 不是零开头 6-15位 ...

  8. Java基础学习总结(35)——Java正则表达式详解

    在Sun的Java JDK 1.40版本中,Java自带了支持正则表达式的包,本文就抛砖引玉地介绍了如何使用java.util.regex包. 可粗略估计一下,除了偶尔用Linux的外,其他Linu  ...

  9. Java基础 -- 字符串(格式化输出、正则表达式)

    一 字符串 1.不可变String String对象是不可变的,查看JDK文档你就会发现,String类中每一个看起来会修改String值的方法,实际上都是创建一个全新的String对象,以包含修改后 ...

随机推荐

  1. inno setup 1

      1.简单脚本 [setup] AppName=Test AppVerName=Test DefaultDirName="d:\setup\app" AppVersion=1.0 ...

  2. slf4j(simple logging facade for java)

    http://www.tuicool.com/articles/IfeUfq   slf4j(simple logging facade for java)是Java的简单的日志门面,它 不是具体的日 ...

  3. IOS NSArray 倒序

    NSMutableArray *array = [NSMutableArray arrayWithObjects:@"1",@"2",@"3" ...

  4. shell 各种循环判断

    shell支持的循环有 Shell if else Shell case esac Shell for循环 Shell while循环 Shell until循环

  5. MyBaits 错误分析

    错误原因:在DAO的映射文件中,在映射标签中的type类型写成DAO类了,应该写成javaBean

  6. ==与equals()方法的不同

    ==比较分为两种情况:基本数据类型比较与引用数据类型比较 1.基本数据类型,根据基本数据类型的值是否相等来判断,相等则返回true,不相等则返回false.两端数据类型可以不同,如果转换后的数值相等, ...

  7. ReactiveCocoa / RxSwift 笔记一

    原创:转载请注明出处 ReactiveCocoa / RxSwift Native app有很大一部分的时间是在等待事件发生,然后响应事件,比如 1.等待网络请求完成, 2.等待用户的操作, 3.等待 ...

  8. C++的精髓——虚函数

    虚函数为了重载和多态的需要,在基类中是由定义的,即便定义是空,所以子类中可以重写也可以不写基类中的函数! 纯虚函数在基类中是没有定义的,必须在子类中加以实现,很像java中的接口函数! 虚函数 引入原 ...

  9. java基本输入型数据Scanner

    import java.util.Scanner; public class Example2_3 { public static void main (String args[ ]){ System ...

  10. HDU 1686 Oulipo(KMP+计算匹配成功次数)

    一开始总是超时,后来发现还是方法没找对,这个跟普通KMP不太一样的就是,KMP匹配成功的时候会完全跳过已经匹配成功的匹配段,至少我掌握的是.那么如何避免这样的问题呢,举个栗子啊 原串为ABABA,模式 ...