Java正則表達式入门

Java正則表達式入门

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。


 众所周知,在程序开发中,难免会遇到须要匹配、查找、替换、推断字符串的情况发生,而这些情况有时又比較复杂,假设用纯编码方式解决,往往会浪费程序猿的时间及精力。因此,学习及使用正則表達式,便成了解决这一矛盾的主要手段。

 大 家都知道,正則表達式是一种能够用于模式匹配和替换的规范,一个正則表達式就是由普通的字符(比如字符a到z)以及特殊字符(元字符)组成的文字模式,它 用以描写叙述在查找文字主体时待匹配的一个或多个字符串。正則表達式作为一个模板,将某个字符模式与所搜索的字符串进行匹配。

  自从jdk1.4推出java.util.regex包,就为我们提供了非常好的JAVA正則表達式应用平台。

 

 由于正則表達式是一个非常庞杂的体系,所以我仅例举些入门的概念,很多其它的请參阅相关书籍及自行摸索。

// 反斜杠

/t 间隔 (‘/u0009’)

/n 换行 (‘/u000A’)

/r 回车 (‘/u000D’)

/d 数字 等价于[0-9]

/D 非数字 等价于[^0-9]

/s 空白符号 [/t/n/x0B/f/r]

/S 非空白符号 [^/t/n/x0B/f/r]

/w 单独字符 [a-zA-Z_0-9]

/W 非单独字符 [^a-zA-Z_0-9]

/f 换页符

/e Escape

/b 一个单词的边界

/B 一个非单词的边界

/G 前一个匹配的结束

^为限制开头

^java     条件限制为以Java为开头字符

$为限制结尾

java$     条件限制为以java为结尾字符

.  条件限制除/n以外随意一个单独字符


java..     条件限制为java后除换行外随意两个字符

添�特定限制条件「[]」

[a-z]     条件限制在小写a to z范围中一个字符

[A-Z]     条件限制在大写A to Z范围中一个字符

[a-zA-Z] 条件限制在小写a to z或大写A to Z范围中一个字符

[0-9]     条件限制在小写0 to 9范围中一个字符

[0-9a-z] 条件限制在小写0 to 9或a to z范围中一个字符

[0-9[a-z]] 条件限制在小写0 to 9或a to z范围中一个字符(交集)

[]中添�^后加再次限制条件「[^]」

[^a-z]     条件限制在非小写a to z范围中一个字符

[^A-Z]     条件限制在非大写A to Z范围中一个字符

[^a-zA-Z] 条件限制在非小写a to z或大写A to Z范围中一个字符

[^0-9]     条件限制在非小写0 to 9范围中一个字符

[^0-9a-z] 条件限制在非小写0 to 9或a to z范围中一个字符

[^0-9[a-z]] 条件限制在非小写0 to 9或a to z范围中一个字符(交集)

在限制条件为特定字符出现0次以上时,能够使用「*」

J*     0个以上J

.*     0个以上随意字符

J.*D     J与D之间0个以上随意字符

在限制条件为特定字符出现1次以上时,能够使用「+」

J+     1个以上J

.+     1个以上随意字符

J.+D     J与D之间1个以上随意字符

在限制条件为特定字符出现有0或1次以上时,能够使用「?」

JA?     J或者JA出现

限制为连续出现指定次数字符「{a}」

J{2}     JJ

J{3}     JJJ

文字a个以上,而且「{a,}」

J{3,}     JJJ,JJJJ,JJJJJ,???(3次以上J并存)

文字个以上,b个以下「{a,b}」

J{3,5}     JJJ或JJJJ或JJJJJ

两者取一「|」

J|A     J或A

Java|Hello     Java或Hello

 

「()」中规定一个组合类型

比方,我查询<a href=/”index.html/”>index</a>中<a href></a>间的数据,可写作<a.*href=/”.*/”>(.+?)</a>

在使用Pattern.compile函数时,能够添�控制正則表達式的匹配行为的參数:

Pattern Pattern.compile(String regex, int flag)

flag的取值范围例如以下:

Pattern.CANON_EQ     当且仅当两个字符的”正规分解(canonical decomposition)”都全然同样的情况下,才认定匹配。比方用了这个标志之后,表达式”a/u030A”会匹配”?”。默认情况下,不考虑”规 范相等性(canonical equivalence)”。

Pattern.CASE_INSENSITIVE(?i)     默认情况下,大写和小写不明感的匹配仅仅适用于US-ASCII字符集。这个标志能让表达式忽略大写和小写进行匹配。要想对Unicode字符进行大小不明感的匹 配,仅仅要将UNICODE_CASE与这个标志合起来即可了。

Pattern.COMMENTS(?x)     在这样的模式下,匹配时会忽略(正則表達式里的)空格字符(译者注:不是指表达式里的”//s”,而是指表达式里的空格,tab,回车之类)。凝视从#開始,一直到这行结束。能够通过嵌入式的标志来启用Unix行模式。

Pattern.DOTALL(?s)     在这样的模式下,表达式’.’能够匹配随意字符,包括表示一行的结束符。默认情况下,表达式’.’不匹配行的结束符。

Pattern.MULTILINE

(?m)     在这样的模式下,’^’和’$’分别匹配一行的開始和结束。此外,’^’仍然匹配字符串的開始,’$’也匹配字符串的结束。默认情况下,这两个表达式仅仅匹配字符串的開始和结束。

Pattern.UNICODE_CASE

(?u)     在这个模式下,假设你还启用了CASE_INSENSITIVE标志,那么它会对Unicode字符进行大写和小写不明感的匹配。默认情况下,大写和小写不敏感的匹配仅仅适用于US-ASCII字符集。

Pattern.UNIX_LINES(?d)     在这个模式下,仅仅有’/n’才被认作一行的中止,而且与’.’,’^’,以及’$’进行匹配。

抛开空泛的概念,以下写出几个简单的Java正则用例:

◆比方,在字符串包括验证时

//查找以Java开头,随意结尾的字符串

  Pattern pattern = Pattern.compile(“^Java.*”);

  Matcher matcher = pattern.matcher(“Java不是人”);

  boolean b= matcher.matches();

  //当条件满足时,将返回true,否则返回false

  System.out.println(b);

◆以多条件切割字符串时

Pattern pattern = Pattern.compile(“[, |]+”);

String[] strs = pattern.split(“Java Hello World  Java,Hello,,World|Sun”);

for (int i=0;i<strs.length;i++) {

    System.out.println(strs[i]);

}

◆文字替换(首次出现字符)

Pattern pattern = Pattern.compile(“正則表達式”);

Matcher matcher = pattern.matcher(“正則表達式 Hello World,正則表達式 Hello World”);

//替换第一个符合正则的数据

System.out.println(matcher.replaceFirst(“Java”));

◆文字替换(所有)

Pattern pattern = Pattern.compile(“正則表達式”);

Matcher matcher = pattern.matcher(“正則表達式 Hello World,正則表達式 Hello World”);

//替换第一个符合正则的数据

System.out.println(matcher.replaceAll(“Java”));

◆文字替换(置换字符)

Pattern pattern = Pattern.compile(“正則表達式”);

Matcher matcher = pattern.matcher(“正則表達式 Hello World,正則表達式 Hello World “);

StringBuffer sbr = new StringBuffer();

while (matcher.find()) {

    matcher.appendReplacement(sbr, “Java”);

}

matcher.appendTail(sbr);

System.out.println(sbr.toString());

◆验证是否为邮箱地址

String str=”ceponline@yahoo.com.cn”;

Pattern pattern = Pattern.compile(“[//w//.//-]+@([//w//-]+//.)+[//w//-]+”,Pattern.CASE_INSENSITIVE);

Matcher matcher = pattern.matcher(str);

System.out.println(matcher.matches());

◆去除html标记

Pattern pattern = Pattern.compile(“<.+?>”, Pattern.DOTALL);

Matcher matcher = pattern.matcher(“<a href=/”index.html/”>主页</a>”);

String string = matcher.replaceAll(“”);

System.out.println(string);

◆查找html中相应条件字符串

Pattern pattern = Pattern.compile(“href=/”(.+?)/””);

Matcher matcher = pattern.matcher(“<a href=/”index.html/”>主页</a>”);

if(matcher.find())

  System.out.println(matcher.group(1));

}

◆截取http://地址

//截取url

Pattern pattern = Pattern.compile(“(http://|https://){1}[//w//.//-/:]+”);

Matcher matcher = pattern.matcher(“dsdsds<http://dsds//gfgffdfd>fdf”);

StringBuffer buffer = new StringBuffer();

while(matcher.find()){             

    buffer.append(matcher.group());       

    buffer.append(“/r/n”);             

System.out.println(buffer.toString());

}

       

◆替换指定{}中文字

String str = “Java眼下的发展史是由{0}年-{1}年”;

String[][] object={new String[]{“//{0//}”,”1995″},new String[]{“//{1//}”,”2007″}};

System.out.println(replace(str,object));

public static String replace(final String sourceString,Object[] object) {

            String temp=sourceString;   

            for(int i=0;i<object.length;i++){

                      String[] result=(String[])object[i];

               Pattern    pattern = Pattern.compile(result[0]);

               Matcher matcher = pattern.matcher(temp);

               temp=matcher.replaceAll(result[1]);

            }

            return temp;

}

◆以正则条件查询指定文件夹下文件

 //用于缓存文件列表

        private ArrayList files = new ArrayList();

        //用于承载文件路径

        private String _path;

        //用于承载未合并的正则公式

        private String _regexp;

       

        class MyFileFilter implements FileFilter {

              /**

               * 匹配文件名称称

               */

              public boolean accept(File file) {

                try {

                  Pattern pattern = Pattern.compile(_regexp);

                  Matcher match = pattern.matcher(file.getName());               

                  return match.matches();

                } catch (Exception e) {

                  return true;

                }

              }

            }

       

        /**

         * 解析输入流

         * @param inputs

         */

        FilesAnalyze (String path,String regexp){

            getFileName(path,regexp);

        }

       

        /**

         * 分析文件名称并添�files

         * @param input

         */

        private void getFileName(String path,String regexp) {

            //文件夹

              _path=path;

              _regexp=regexp;

              File directory = new File(_path);

              File[] filesFile = directory.listFiles(new MyFileFilter());

              if (filesFile == null) return;

              for (int j = 0; j < filesFile.length; j++) {

                files.add(filesFile[j]);

              }

              return;

            }

   

        /**

         * 显示输出信息

         * @param out

         */

        public void print (PrintStream out) {

            Iterator elements = files.iterator();

            while (elements.hasNext()) {

                File file=(File) elements.next();

                    out.println(file.getPath());   

            }

        }

        public static void output(String path,String regexp) {

            FilesAnalyze fileGroup1 = new FilesAnalyze(path,regexp);

            fileGroup1.print(System.out);

        }

   

        public static void main (String[] args) {

            output(“C://”,”[A-z|.]*”);

        }

Java正则的功用还有非常多,其实仅仅要是字符处理,就没有正则做不到的事情存在。(当然,正则解释时较耗时间就是了|||……)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/118790.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • random函数用法笔记

    random函数用法笔记1.导入random模块importrandom2.生成(n,m)之间的随机整数>>>importrandom>>>a=random.randint(1,10)#1<=a<=10且n,m大小必须n<m>>>print(a)3>>>3.取0-1之间随机浮点数…

  • 初中英语语法(007)-比较级·最高级

    初中英语语法(007)-比较级·最高级比较级·最高级英语句子中,将比较两个主体的方法叫做“比较句型”。其中,像“A比B更……”的表达方式称为比较级。“A是所有人中最高的”,这种表达方式称为最高级,组成句子的方式是将形容词或副词变化成比较级或最高级的形态。“他比她更高”这句话里得“更”怎么表现呢?这需要形容词按照一定规则变化。1、变化规则(1)+er/est:short-shorter-shortest(2)原形以e…

  • 漫谈数据仓库之拉链表(原理、设计以及在Hive中的实现)

    漫谈数据仓库之拉链表(原理、设计以及在Hive中的实现)0x00前言本文将会谈一谈在数据仓库中拉链表相关的内容,包括它的原理、设计、以及在我们大数据场景下的实现方式。全文由下面几个部分组成:先分享一下拉链表的用途、什么是拉链表。通过一些小的使用场景来对拉链表做近一步的阐释,以及拉链表和常用的切片表的区别。举一个具体的应用场景,来设计并实现一份拉链表,最后并通过一些例子说明如何使用我们设计的这张表(因为现在Hive的大规模使用

    2022年10月17日
  • spug自动化运维平台开源项目部署搭建

    spug自动化运维平台开源项目部署搭建灵活、强大、功能全面的开源运维平台

  • 【离散数学】单射、满射和双射的定义、区别

    【离散数学】单射、满射和双射的定义、区别满射:对任意b,存在a满足f(a)=b~即:值域y是满的,每个y都有x对应,不存在某个y没有x对应的情况~单射:(one-to-onefunction)一对一函数,x不同则y不同~即:没有一个x对应两个y,也没有一个y有对应两个x~双射:既是满射,也是单射~即:每个y都有x对应,而且都是一一对应~…

  • VS 2013安装教程「建议收藏」

    VS 2013安装教程「建议收藏」1.下载资源此版本是旗舰版,其他版本自行下载http://download.microsoft.com/download/9/3/E/93EA27FF-DB02-4822-8771-DCA0238957E9/vs2013.5_ult_chs.iso?type=ISO2.装载光盘3.右击应用程序,选择“以管理员身份运行”4.选择安装路径并同意许可,点击下一步。5.选择安装的功能(根据自己需要选择),点击安装6.等待安装即可7….

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号