本文内容来源于  历经5年锤练--史上最适合初学者入门的Java基础视频

例:要求QQ号长度为5~15位,不能以0开头

String qq="123456";
String regex="[1-9][0-9]{4,14}";//正则表达式
boolean b = qq.matches(regex);
System.out.println(qq+":"+b);//qq:true

正则表达式用于操作字符串数据。
通过一些特定的符号来体现。
为了掌握正则表达式,必须学习一些符号。

虽然简化了,但是阅读性差。

JDK API 1.60 中文版
java.lang String matches 正则表达式
常用:
1.字符

x     字符 x
\\    反斜线字符

2.字符类

[abc]         a、b 或 c(简单类)
[^abc]       任何字符,除了 a、b 或 c(否定)
[a-zA-Z]       a 到 z 或 A 到 Z,两头的字母包括在内(范围)
[a-d[m-p]]      a 到 d 或 m 到 p:[a-dm-p](并集)
[a-z&&[def]]    d、e 或 f(交集)
[a-z&&[^bc]]    a 到 z,除了 b 和 c:[ad-z](减去)
[a-z&&[^m-p]]    a 到 z,而非 m 到 p:[a-lq-z](减去)

3.预定义字符类

.     任何字符(与行结束符可能匹配也可能不匹配)
\d     数字:[0-9]
\D     非数字: [^0-9]
\s    空白字符:[ \t\n\x0B\f\r]
\S     非空白字符:[^\s]
\w    单词字符:[a-zA-Z_0-9]
\W    非单词字符:[^\w]

4.边界匹配器

^    行的开头
$    行的结尾
\b   单词边界

5.Greedy 数量词

X?       X,一次或一次也没有
X*       X,零次或多次
X+       X,一次或多次
X{n}     X,恰好 n 次
X{n,}      X,至少 n 次
X{n,m}     X,至少 n 次,但是不超过 m 次

正则表达式对字符串的常见操作:
1, 匹配。
其实使用的就是String类中的matches方法。

//匹配手机号码是否正确。
String tel = "15800001111";
String regex = "1[358]\\d{9}";
boolean b = tel.matches(regex);
System.out.println(tel+":"+b);

2,切割。
其实使用的就是String类中的split方法。

String str = "zhangsan      xiaoqiang  zhaoliu";
String[] names = str.split(" +");
//输出结果如下zhangsan
xiaoqiang
zhaoliu String str = "zhangsan.xiaoqiang.zhaoliu";
String[] names = str.split("\\.");
//输出结果如下zhangsan
xiaoqiang
zhaoliu
组:((A)(B(C))) 
通过从左到右计算其开括号来编号,组零始终代表整个表达式
String str = "zhangsanttttxiaoqiangmmmmmmzhaoliu";
String[] names = str.split("(.)\\1+");//编号代表第一组 for(String name : names){
System.out.println(name);
//输出结果如下zhangsan
xiaoqiang
zhaoliu

3,替换。
其实使用的就是String类中的replaceAll()方法。

String str = "zhangsanttttxiaoqiangmmmmmmzhaoliu";
str = str.replaceAll("(.)\\1+","#");
//将叠词替换为#
//输出结果如下
/* zhangsan#xiaoqiang#zhaoliu */
str = str.replaceAll("(.)\\1+", "$1");
//$ 获取前一个参数中的第一组
//输出结果如下
/* zhangsantxiaoqiangmzhaoliu */
System.out.println(str); String tel = "15800001111";
tel = tel.replaceAll("(\\d{3})\\d{4}(\\d{4})", "$1****$2");
//输出结果如下
/* 158****1111 */
System.out.println(tel);

4,获取。

将正则规则进行对象的封装。
Pattern p = Pattern.compile("a*b");
通过正则对象的matcher方法字符串相关联。获取要对字符串操作的匹配器对象Matcher .
Matcher m = p.matcher("aaaaab");
通过Matcher匹配器对象的方法对字符串进行操作。
boolean b = m.matches();

String str = "da jia hao,ming tian bu fang jia!";
String regex = "\\b[a-z]{3}\\b"; //1,将正则封装成对象。
Pattern p = Pattern.compile(regex);
//2, 通过正则对象获取匹配器对象。
Matcher m = p.matcher(str); //使用Matcher对象的方法对字符串进行操作。
//既然要获取三个字母组成的单词
//查找。 find();
while(m.find()){
System.out.println(m.group());//获取匹配的子序列
System.out.println(m.start()+":"+m.end());
}
//输出结果:
jia
3:6
hao
7:10
jia
29:32

5.正则表达式练习

1,治疗口吃:我我...我我...我我我要...要要要要...要要要要..学学学学学...学学编编...编编编编..编..程程...程程...程程程
2,对ip地址排序。
3,对邮件地址校验。

1,治口吃。

String str = "我我...我我...我我我要...要要要要...要要要要..学学学学学...学学编编...编编编编..编..程程...程程...程程程";

//1,将字符串中.用替换去掉。
str = str.replaceAll("\\.+", "");
System.out.println(str); //2,替换叠词。
str = str.replaceAll("(.)\\1+", "$1");
System.out.println(str);
//输出:我要学编程

2. ip地址排序。
192.168.10.34 127.0.0.1 3.3.3.3 105.70.11.55

String ip_str = "192.168.10.34 127.0.0.1 3.3.3.3 105.70.11.55";
//1,为了让ip可以按照字符串顺序比较,只要让ip的每一段的位数相同。
//所以,补零,按照每一位所需做多0进行补充。每一段都加两个0.
ip_str = ip_str.replaceAll("(\\d+)", "00$1");
System.out.println(ip_str);
//输出:
//00192.00168.0010.0034 00127.000.000.001 003.003.003.003 00105.0070.0011.0055
//然后每一段保留数字3位。
ip_str = ip_str.replaceAll("0*(\\d{3})", "$1");
System.out.println(ip_str);
//输出:
//192.168.010.034 127.000.000.001 003.003.003.003 105.070.011.055 //1,将ip地址切出。
String[] ips = ip_str.split(" +");
TreeSet<String> ts = new TreeSet<String>();//自动排序
for(String ip : ips){
ts.add(ip);
} for(String ip : ts){
// System.out.println(ip);
/* 输出:
* 003.003.003.003
* 105.070.011.055
* 127.000.000.001
* 192.168.010.034
*/
System.out.println(ip.replaceAll("0*(\\d+)", "$1"));
/* 输出:
* 3.3.3.3
* 105.70.11.55
* 127.0.0.1
* 192.168.10.34
*/
}

3. 对邮件地址校验。

String mail = "abc1@sina.com.cn";
String regex = "[a-zA-Z0-9_]+@[a-zA-Z0-9]+(\\.[a-zA-Z]{1,3})+"; //一般不用这个,网上有标准 regex = "\\w+@\\w+(\\.\\w+)+";//1@1.1 笼统式匹配
boolean b = mail.matches(regex);
System.out.println(mail+":"+b);

网页爬虫:其实就一个程序用于在互联网中获取符合指定规则的数据。
爬取邮箱地址。

public static void main(String[] args) throws IOException {
List<String> list = getMailsByWeb();
for(String mail : list){
System.out.println(mail);
}
}
public static List<String> getMailsByWeb() throws IOException {
  //1,读取源文件。
  //BufferedReader bufIn = new BufferedReader(new FileReader("c:\\mail.html"));
  URL url = new URL("http://192.168.1.100:8080/myweb/mail.html");
  BufferedReader bufIn = new BufferedReader(new InputStreamReader(url.openStream()));
  //2,对读取的数据进行规则的匹配。从中获取符合规则的数据.
  String mail_regex = "\\w+@\\w+(\\.\\w+)+";
  List<String> list = new ArrayList<String>();   Pattern p = Pattern.compile(mail_regex);
  String line = null;
  while((line=bufIn.readLine())!=null){
    Matcher m = p.matcher(line);
    while(m.find()){
    //3,将符合规则的数据存储到集合中。
    list.add(m.group());
    }
  }
  return list;
}

java学习——正则表达式的更多相关文章

  1. Java Script正则表达式语法学习

    今天在做页面交互验证时,在HTML里面第一反应居然用了Java 处理正则表达式的语法... ---------------------------------题记 学习来源 http://www.ru ...

  2. Java 学习(7):java 日期时间 & 正则表达式

    目录 --- 日期时间 --- 正则表达式 日期时间:java.util 包提供了 Date 类来封装当前的日期和时间. Date 类提供两个构造函数来实例化 Date 对象. 构造函数:用于初始化对 ...

  3. Java学习笔记(5)----使用正则表达式解决Google Code Jam Qualification2009赛题 Alien Language

    原题地址:https://code.google.com/codejam/contest/90101/dashboard#s=p0 题目描述: Problem After years of study ...

  4. JAVA中正则表达式学习总结

    一.JAVA中正则表达式相关的类 1. java.util.regex.Pattern 该类用于编译模式,模式可以理解为一个正则表达式,比如:a*b. 用法如下: // 创建模式 Pattern p ...

  5. Java学习笔记(6)---正则表达式,方法

    1.正则表达式: a.定义: 正则表达式定义了字符串的模式. 正则表达式可以用来搜索.编辑或处理文本. 正则表达式并不仅限于某一种语言,但是在每种语言中有细微的差别. 在Java,一个字符串其实就是一 ...

  6. 《Java学习笔记(第8版)》学习指导

    <Java学习笔记(第8版)>学习指导 目录 图书简况 学习指导 第一章 Java平台概论 第二章 从JDK到IDE 第三章 基础语法 第四章 认识对象 第五章 对象封装 第六章 继承与多 ...

  7. Java学习-041-颜色工具类(RGB,HEX)

    在日常的网页开发中,经常需要进行颜色数值获取.转换,例如获取红色,获取蓝色,获取绿色,RGB转十六进制颜色,十六进制颜色转RGB等,因而在学习过程中,写了一个小工具类,仅供各位小主参考! 多不闲言,直 ...

  8. java中正则表达式基本用法

    正则表达式是一种可以用于模式匹配和替换的规范,一个正则表达式就是由普通的字符(例如字符a到z)以及特殊字符(元字符)组成的文字模式,它 用以描述在查找文字主体时待匹配的一个或多个字符串.正则表达式作为 ...

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

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

随机推荐

  1. 《FPGA零基础入门到精通视频教程》-第001b讲软件的破解

    高清视频和配套讲义这里下载 http://www.fpgaw.com/thread-68128-1-1.html 优酷视频地址,不是很清楚

  2. Color the ball

    hdu1556:http://acm.hdu.edu.cn/showproblem.php?pid=1556 题意:中文题. 题解:这一题当然可以直接用线段树来打,但是最近在学树状数组,所以用树状数组 ...

  3. 玩死人不偿命的CLOUDSTACK

    玩过CLOUDSTACK(CS)的人,一定不会陌生下面的LOG: 2013-12-27 18:26:43,861 DEBUG [allocator.impl.FirstFitAllocator] (J ...

  4. treap启发式合并

    注意输入v要在建根的前面. #include <cstdio> #include <iostream> #include <algorithm> #include ...

  5. COJ 1002 WZJ的数据结构(二)(splay模板)

    我的LCC,LCT,Splay格式终于统一起来了... 另外..这个形式的Splay是标准的Splay(怎么鉴别呢?看Splay函数是否只传了一个变量node就行),刘汝佳小白书的Splay写的真是不 ...

  6. Delphi 托盘程序实现 转

    unit MainUnit; interface uses  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, F ...

  7. A - Jungle Roads - poj 1251(简单)

    想必看这道题的时候直接看数据还有那个图就能明白什么意思吧,说的已经很清楚了,每个点都有一些相连的点和权值,求出来如果连接所有点,最小的权值是多少,赤裸裸的最小生成树... ************** ...

  8. J - Borg Maze - poj 3026(BFS+prim)

    在一个迷宫里面需要把一些字母.也就是 ‘A’ 和 ‘B’连接起来,求出来最短的连接方式需要多长,也就是最小生成树,地图需要预处理一下,用BFS先求出来两点间的最短距离, *************** ...

  9. [置顶] Android开发之ProcessState和IPCThreadState类分析

    在Android中ProcessState是客户端和服务端公共的部分,作为Binder通信的基础,ProcessState是一个singleton类,每个 进程只有一个对象,这个对象负责打开Binde ...

  10. Linux下Django的安装

    1.下载Django.地址:https://www.djangoproject.com/download/ 2.解压3中得到的Django-1.6.2.tar.gz.使用下面的命令进行解压,解压后在当 ...