java学习——正则表达式

本文内容来源于  历经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 次

public class RegexDemo {

public static void main(String[] args) {

/*
* 正则表达式对字符串的常见操作:
* 1, 匹配。
* 其实使用的就是String类中的matches方法。
*
* 2,切割。
* 其实使用的就是String类中的split方法。
*
* 3,替换。
* 其实使用的就是String类中的replaceAll()方法。
*
* 4,获取。
*
*/

functionDemo_4();
}

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

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();
System.out.println(str);
while(m.find()){
System.out.println(m.group());//获取匹配的子序列

System.out.println(m.start()+":"+m.end());
}
}

/*
* 替换
*/
public static void functionDemo_3() {

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

String tel = "15800001111";//158****1111;

tel = tel.replaceAll("(\\d{3})\\d{4}(\\d{4})", "$1****$2");

System.out.println(tel);

}

/*
* 切割。
*
* 组:((A)(B(C)))
*/
public static void functionDemo_2(){

// String str = "zhangsan xiaoqiang zhaoliu";
// String[] names = str.split(" +");//输出结果如下
/* zhangsan
xiaoqiang
zhaoliu
*/
// String str = "zhangsan.xiaoqiang.zhaoliu";
// String[] names = str.split("\\.");//输出结果如下
/* zhangsan
xiaoqiang
zhaoliu
*/
String str = "zhangsanttttxiaoqiangmmmmmmzhaoliu";

String[] names = str.split("(.)\\1+");//编号代表第一组

for(String name : names){
System.out.println(name);//输出结果如下
/* zhangsan
xiaoqiang
zhaoliu
*/
}
}
/*
* 演示匹配。
*/
public static void functionDemo_1(){

//匹配手机号码是否正确。
String tel = "15800001111";

String regex = "1[358]\\d{9}";

boolean b = tel.matches(regex);
System.out.println(tel+":"+b);
}
}

import java.util.TreeSet;

public class RegexTest {

/**
* @param args
*/
public static void main(String[] args) {

/*
* 1,治疗口吃:我我...我我...我我我要...要要要要...要要要要..学学学学学...学学编编...编编编编..编..程程...程程...程程程
* 2,对ip地址排序。
* 3,对邮件地址校验。
*/
test_3();
}

/*
* 1,治口吃。
*/
public static void test_1(){

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

//1,将字符串中.去掉。 用替换。
str = str.replaceAll("\\.+", "");
System.out.println(str);

//2,替换叠词。
str = str.replaceAll("(.)\\1+", "$1");
System.out.println(str); /* 输出:
* 我要学编程
*/
}
/*
* ip地址排序。
*
* 192.168.10.34 127.0.0.1 3.3.3.3 105.70.11.55
*/
public static void test_2(){

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){
// System.out.println(ip);
/* 输出:
* 192.168.10.34
* 127.0.0.1
* 3.3.3.3
* 105.70.11.55
*/
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
*/
}

}

/*
*对邮件地址校验。
*/
public static void test_3() {

String mail = "[email protected]";

String regex = "[a-zA-Z0-9_][email protected][a-zA-Z0-9]+(\\.[a-zA-Z]{1,3})+"; //一般不用这个,网上有标准

regex = "\\[email protected]\\w+(\\.\\w+)+";//[email protected] 笼统式匹配

boolean b = mail.matches(regex);

System.out.println(mail+":"+b);
}
}

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

/**
* @param args
* @throws IOException
*/
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 bufr = 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 = "\\[email protected]\\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;
}

public static List<String> getMails() throws IOException{

//1,读取源文件。
BufferedReader bufr = new BufferedReader(new FileReader("c:\\mail.html"));

//2,对读取的数据进行规则的匹配。从中获取符合规则的数据.
String mail_regex = "\\[email protected]\\w+(\\.\\w+)+";

List<String> list = new ArrayList<String>();

Pattern p = Pattern.compile(mail_regex);

String line = null;

while((line=bufr.readLine())!=null){

Matcher m = p.matcher(line);
while(m.find()){
//3,将符合规则的数据存储到集合中。
list.add(m.group());
}

}
return list;

}

}

时间: 2024-11-17 02:24:12

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

Java学习系列(二十四)Java正则表达式详解

转载请注明出处:http://blog.csdn.net/lhy_ycu/article/details/45501777 前言 正则表达式可以说是用来处理字符串的一把利器,它是一个专门匹配n个字符串的字符串模板,本质是查找和替换.在实例演示之前先了解一下Pattern.Matcher这两个工具类,Pattern:编译好的带匹配的模板(如:Pattern.compile("[a-z]{2}");/ / 取2个小写字母):Matcher:匹配目标字符串后产生的结果(如:pattern.m

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

原题地址:https://code.google.com/codejam/contest/90101/dashboard#s=p0 题目描述: Problem After years of study, scientists at Google Labs have discovered an alien language transmitted from a faraway planet. The alien language is very unique in that every word

2016最新Java学习计划

一.Java学习路线图 二.Java学习路线图--视频篇 六大阶段 学完后目标 知识点 配套免费资源(视频+笔 记+源码+模板) 密码        第一阶段 Java基础 入门 学习周期: 35天 学完后目标: 1.可进行小型应用程序开发 2.对数据库进行基本的增删改查管理 市场价值:¥5000 计算机基础知识 计算机基础.DOS常用命令.Java概述.JDK环境安装配置.环境变量配置.Java程序入门 1.2015年Java基础视频-深入浅出精华版(强烈推荐) 2.历经5年锤炼(适合初学者入

Java基础---正则表达式

正则表达式 一.概述 1. 概念:符合一定规则的表达式. 2. 作用:用于专门操作字符串. 3. 特点:用于一些特定的符号来表示一些代码操作,这样可以简化书写.所以学习正则表达式,就是在学习一些特殊符号的使用. 4. 好处:可以简化对字符串的复杂操作. 5. 弊端:符合定义越多,正则越长,阅读性越差. 二.常见符号 说明:X表示字符X或者匹配的规则. 1.字符 x                  字符 x \\                 反斜线字符 \t                 

Java学习路线&amp;怎么学习Java

1 概述 学过一段时间的同学一定会觉得Java学习最头疼的不是语法结构的繁杂,而是Java本身体系结构的庞大.以至于自己不知道接下去该学什么,或者什么样的知识才会对后续的学习有帮助.本节内容将让大家对Java学习的路线有个宏观的把握.在与市场接轨的前提下,我们会推荐给各位同学相关学习的方向和技术,以及学习到何种程度才能适应基本的工作. 好多同学可能会有如下的疑问: l  我已经学完JDBC了,那样参加工作够用了吗? l  Java SE学到什么样的程度算是OK了呢? l  东西好多啊,我改怎么学

最全Java学习路线图——Java学习指南

准备篇 适用/适合人群:适合基础小白 目标:掌握JavaSE. ●技术点小节: 1.开发工具的安装配置的介绍 2.JDK安装 3.DOS环境编程 4.Eclipse的安装使用 ●JAVA基础 1.基本的语法规范 2.数据类型 3.流程控制 4.函数 ●初识JavaOOP 1.类,对象,面向编程思想 2.字符串类 3.随机数 4.正则表达式 5.递归的使用 ●JavaOOP基础 1.JavaOOP之封装 2.JavaOOP之继承 3.JavaOOP之多态 4.Java访问修饰符 5.Java接口

Java 学习笔记(2015.7.20~24)

Java 学习笔记(2015.7.20~24) Java Java 学习笔记(2015.7.20~24) 1.StringBuffer与StringBuilder的区别: 2.基本数据类型包装类 3.Date.Calendar.DateFormat等与时间相关的类 1.常用类String 2.正则表达式 3.常用类 StringBuffer 代表可变的字符序列 拆箱与装箱 包装类的应用 匿名内部类 数组 day11 day12 day13 day14 day11 父类中使用public定义的方法

Java学习-049-正则工具类

自去年九月份决定再次入学和职业资格进阶,开始备战二者考试至今,以及当下进行中的职称申请,犹如孤独的狼,不断前行在路上,而今凡凡总总的已历8月... 不感慨了,如下为一园友需要的正则工具类,直接上码: 1 public class RegUtils { 2 private static Logger logger = Logger.getLogger(RegUtils.class.getName()); 3 private static String msg = ""; 4 privat

【Java学习笔记】几个实用类

作者:gnuhpc     出处:http://www.cnblogs.com/gnuhpc/ 1.File类为管理文件和目录提供了方法,其对象表示一个文件或者目录.它提供了若干方法对文件或文件夹进行操作.其中的list()方法和listFiles()方法可以起到定位特定文件的作用. 2.Object类,是所有Java类的祖先,若一个类声明时没有包含extends关键字,则其直接继承于Objetc类.其中有许多重要方法: equals(),notify(),notifyAll(),wait(),