Java中正则表达式的使用

在Java中,我们为了查找某个给定字符串中是否有需要查找的某个字符或者子字串、或者对字符串进行分割、或者对字符串一些字符进行替换/删除,一般会通过if-else、for 的配合使用来实现这些功能 。如下所示:

  1. public class Test{
  2. public static void main(String args[]) {
  3. String str="@Shang Hai Hong Qiao Fei Ji Chang";
  4. boolean rs = false;
  5. for(int i=0;i<str.length();i++){
  6. char z=str.charAt(i);
  7. if('a' == z || 'F' == z) {
  8. rs  = true;
  9. break;
  10. }else{
  11. rs= false;
  12. }
  13. }
  14. System.out.println(rs);
  15. }
  16. }

这种方法使用简单直观,但是 难以解决复杂的工作,而且代码量也会增加很多,不利于维护。

这时,我们可以使用正则表达式来实现这些功能,而且代码简单易维护。下面就来介绍了Java中对字符串的正则表达式的几个常用的功能,具体情况如下所示(其中用到了java.util.regex包):

1.Java中在某个字符串中查询某个字符或者某个子字串

  1. String s = "@Shang Hai Hong Qiao Fei Ji Chang";   
  2. String regEx = "a|F"; //表示a或F
  3. Pattern pat = Pattern.compile(regEx);
  4. Matcher mat = pat.matcher(s);
  5. boolean rs = mat.find();

如果s中有regEx,那么rs为true,否则为flase。

如果想在查找时忽略大小写,则可以写成Pattern pat=Pattern.compile(regEx,Pattern.CASE_INSENSITIVE);

2.在某个文件中获取一段字符串

  1. String regEx = ".+\(.+)$";
  2. String s = "c:\test.txt";
  3. Pattern pat = Pattern.compile(regEx);
  4. Matcher mat = pat.matcher(s);
  5. boolean rs = mat.find();
  6. for(int i=1;i<=mat.groupCount();i++){
  7.   System.out.println(mat.group(i));
  8. }

 以上的执行结果为test.txt,提取的字符串储存在mat.group(i)中,其中i最大值为mat.groupCount();

3.对字符串的分割

  1. String regEx=":";
  2. Pattern pat = Pattern.compile(regEx);
  3. String[] rs = pat.split("aa:bb:cc");

 执行后,r就是{"aa","bb","cc"}

如果用正则表达式分割就如上所示,一般我们都会使用下面更简单的方法:

  1. String s = "aa:bb:cc";
  2. String[] rs=s.split(":");

4.字符串的替换/删除

  1. String regEx="@+"; //表示一个或多个@
  2. Pattern pat=Pattern.compile(regEx);
  3. Matcher mat=pat.matcher("@@aa@b cc@@");
  4. String s=mat.replaceAll("#");

 结果为"##aa#b cc##"

  

 如果要把字符串中的@都给删除,只用要空字符串替换就可以了:

  1. String s=mat.replaceAll("");

 结果为"aab cc"

注:对Pattern类的说明: 

      1.public final class java.util.regex.Pattern是正则表达式编译后的表达法。

下面的语句将创建一个Pattern对象并赋值给句柄pat:Pattern pat = Pattern.compile(regEx);

      有趣的是,Pattern类是final类,而且它的构造器是private。也许有人告诉你一些设计模式的东西,或者你自己查有关资料。这里的结论是:Pattern类不能被继承,我们不能通过new创建Pattern类的对象。

       因此在Pattern类中,提供了2个重载的静态方法,其返回值是Pattern对象(的引用)。如:

  1. public static Pattern compile(String regex) {
  2. return new Pattern(regex, 0);
  3. }

当然,我们可以声明Pattern类的句柄,如Pattern pat = null;

2.pat.matcher(str)表示以用Pattern去生成一个字符串str的匹配器,它的返回值是一个Matcher类的引用。

       我们可以简单的使用如下方法:boolean rs = Pattern.compile(regEx).matcher(str).find();

正则表达式以过滤特殊字符:

Java代码  
  1. // 过滤特殊字符
  2. public   static   String StringFilter(String   str)   throws   PatternSyntaxException   {
  3. // 只允许字母和数字
  4. // String   regEx  =  "[^a-zA-Z0-9]";
  5. // 清除掉所有特殊字符
  6. String regEx="[`~!@#$%^&*()+=|{}':;',\\[\\].<>/?~!@#¥%……&*()——+|{}【】‘;:”“’。,、?]";
  7. Pattern   p   =   Pattern.compile(regEx);
  8. Matcher   m   =   p.matcher(str);
  9. return   m.replaceAll("").trim();
  10. }
  11. @Test
  12. public    void   testStringFilter()   throws   PatternSyntaxException   {
  13. String   str   =   "*adCVs*34_a _09_b5*[/435^*&城池()^$$&*).{}+.|.)%%*(*.中国}34{45[]12.fd'*&999下面是中文的字符¥……{}【】。,;’“‘”?";
  14. System.out.println(str);
  15. System.out.println(StringFilter(str));
  16. }

抛开空泛的概念,下面写出几个简单的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|.]*"); 

        }

  常用的正则表达式:

匹配特定数字:

^[1-9]d*$    //匹配正整数

^-[1-9]d*$   //匹配负整数

^-?[1-9]d*$   //匹配整数

^[1-9]d*|0$  //匹配非负整数(正整数 + 0)

^-[1-9]d*|0$   //匹配非正整数(负整数 + 0)

^[1-9]d*.d*|0.d*[1-9]d*$   //匹配正浮点数

^-([1-9]d*.d*|0.d*[1-9]d*)$  //匹配负浮点数

^-?([1-9]d*.d*|0.d*[1-9]d*|0?.0+|0)$  //匹配浮点数

^[1-9]d*.d*|0.d*[1-9]d*|0?.0+|0$   //匹配非负浮点数(正浮点数 + 0)

^(-([1-9]d*.d*|0.d*[1-9]d*))|0?.0+|0$  //匹配非正浮点数(负浮点数 + 0)

评注:处理大量数据时有用,具体应用时注意修正



匹配特定字符串:

^[A-Za-z]+$  //匹配由26个英文字母组成的字符串

^[A-Z]+$  //匹配由26个英文字母的大写组成的字符串

^[a-z]+$  //匹配由26个英文字母的小写组成的字符串

^[A-Za-z0-9]+$  //匹配由数字和26个英文字母组成的字符串

^w+$  //匹配由数字、26个英文字母或者下划线组成的字符串



在使用RegularExpressionValidator验证控件时的验证功能及其验证表达式介绍如下:



只能输入数字:“^[0-9]*$”

只能输入n位的数字:“^d{n}$”

只能输入至少n位数字:“^d{n,}$”

只能输入m-n位的数字:“^d{m,n}$”

只能输入零和非零开头的数字:“^(0|[1-9][0-9]*)$”

只能输入有两位小数的正实数:“^[0-9]+(.[0-9]{2})?$”

只能输入有1-3位小数的正实数:“^[0-9]+(.[0-9]{1,3})?$”

只能输入非零的正整数:“^+?[1-9][0-9]*$”

只能输入非零的负整数:“^-[1-9][0-9]*$”

只能输入长度为3的字符:“^.{3}$”

只能输入由26个英文字母组成的字符串:“^[A-Za-z]+$”

只能输入由26个大写英文字母组成的字符串:“^[A-Z]+$”

只能输入由26个小写英文字母组成的字符串:“^[a-z]+$”

只能输入由数字和26个英文字母组成的字符串:“^[A-Za-z0-9]+$”

只能输入由数字、26个英文字母或者下划线组成的字符串:“^w+$”

验证用户密码:“^[a-zA-Z]w{5,17}$”正确格式为:以字母开头,长度在6-18之间,



只能包含字符、数字和下划线。

验证是否含有^%&’,;=?$”等字符:“[^%&’,;=?$x22]+”

只能输入汉字:“^[u4e00-u9fa5],{0,}$”

验证Email地址:“^w+[-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$”

验证InternetURL:“^http://([w-]+.)+[w-]+(/[w-./?%&=]*)?$”

验证电话号码:“^((d{3,4})|d{3,4}-)?d{7,8}$”



正确格式为:“XXXX-XXXXXXX”,“XXXX-XXXXXXXX”,“XXX-XXXXXXX”,



“XXX-XXXXXXXX”,“XXXXXXX”,“XXXXXXXX”。

验证身份证号(15位或18位数字):“^d{15}|d{}18$”

验证一年的12个月:“^(0?[1-9]|1[0-2])$”正确格式为:“01”-“09”和“1”“12”

验证一个月的31天:“^((0?[1-9])|((1|2)[0-9])|30|31)$”



正确格式为:“01”“09”和“1”“31”。



匹配中文字符的正则表达式: [u4e00-u9fa5]

匹配双字节字符(包括汉字在内):[^x00-xff]

匹配空行的正则表达式:n[s| ]*r

匹配HTML标记的正则表达式:/< (.*)>.*|< (.*) />/

匹配首尾空格的正则表达式:(^s*)|(s*$)

匹配Email地址的正则表达式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*

匹配网址URL的正则表达式:http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?

android java 字符串正则表达式 分离特殊字符串的更多相关文章

  1. 我的Java开发学习之旅------>工具类:Java使用正则表达式分离出字符串中的中文和英文

    今天看到一个工具类使用正则表达式将一大段字符串中的中文和英文都分离出来了,在此记录一下,读者可以收藏! import java.util.ArrayList; import java.util.Col ...

  2. 在Java中用正则表达式判断一个字符串是否是数字的方法

    package chengyujia; import java.util.regex.Pattern; public class NumberUtil { /** * 判断一个字符串是否是数字. * ...

  3. Java利用正则表达式统计某个字符串出现的次数

    //统计某个字符出现的次数 private void countSubString(){ String string1="香蕉.玉米.面粉"; String string2=&qu ...

  4. java中用正则表达式判断中文字符串中是否含有英文或者数字

    public static boolean includingNUM(String str)throws  Exception{ Pattern p  = Pattern.compile(" ...

  5. Java基础之一组有用的类——使用正则表达式搜索子字符串(TryRegex)

    控制台程序. 正则表达式只是一个字符串,描述了在其他字符串中搜索匹配的模式.但这不是被动地进行字符序列匹配,正则表达式其实是一个微型程序,用于一种特殊的计算机——状态机.状态机并不是真正的机器,而是软 ...

  6. java 正则匹配空格字符串 正则表达式截取字符串

    java 正则匹配空格字符串 正则表达式截取字符串 需求:从一堆sql中取出某些特定字符串: 比如配置的sql语句为:"company_code = @cc and project_id = ...

  7. [改善Java代码]推荐在复杂字符串操作中使用正则表达式

    一.分析  字符串的操作,诸如追加.合并.替换.倒序.分隔等,都是在编码过程中经常用到的,而且Java也提供了append.replace.reverse.split等方法来完成这些操作,它们使用起来 ...

  8. java正则表达式,将字符串中\后的第一个字母变成大写

    java正则表达式,将字符串中\后的第一个字母变成大写 例子是比较简单,注意的是java中的“\\”意义是:我要插入一个正则表达式的反斜线,所以其后面的字符有特殊有意义.所以普通反斜线应该是" ...

  9. Java中用正则表达式截取字符串中

    Java中用正则表达式截取字符串中第一个出现的英文左括号之前的字符串.比如:北京市(海淀区)(朝阳区)(西城区),截取结果为:北京市.正则表达式为() A ".*?(?=\\()" ...

随机推荐

  1. [Luogu 1262] 间谍网络

    题目描述 由于外国间谍的大量渗入,国家安全正处于高度的危机之中.如果A间谍手中掌握着关于B间谍的犯罪证据,则称A可以揭发B.有些间谍收受贿赂,只要给他们一定数量的美元,他们就愿意交出手中掌握的全部情报 ...

  2. cmd解压压缩包

    需要安装有winrar start winrar x C:\Users\systme\Desktop\xxx.rar c:\123

  3. Event Recommendation Engine Challenge分步解析第一步

    一.简介 此项目来自kaggle:https://www.kaggle.com/c/event-recommendation-engine-challenge/ 数据集的下载需要账号,并且需要手机验证 ...

  4. Windows 运行库

    Microsoft Visual C++ 2005 Redistributable - 8.0.61001http://download.microsoft.com/download/8/B/4/8B ...

  5. vscode Live Server使用

    vscode 的Live Server插件可以开启本地服务器

  6. [NIO-2]通道和FileChannel

    通道是什么 通道式(Channel)是java.nio的第二个主要创新.通道既不是一个扩展也不是一项增强,而是全新的.极好的Java I/O示例,提供与I/O服务的直接连接.Channel用于在字节缓 ...

  7. 阅读:重新介绍 JavaScript(JS教程)

    这篇文章是记录自己阅读重新介绍 JavaScript(JS 教程)的记录和个人体会 在线调试代码工具:https://codepen.io/pen 引言 分歧根源:名字Javascript和Java有 ...

  8. sql注入问题-视图-事物-以及存储过程(可视化工具)

    可视化工具(了解) 可视化工具 workbench 视图 视图 是一张虚拟的表 语法: create view 视图表名 as select * from t1; 作用: .他是执行as 后面的sql ...

  9. node的优缺点及应用场景

    Node.js是一个事件驱动I/O服务端JavaScript环境,基于Google的V8引擎(V8引擎执行Javascript的速度非常快,性能非常好) 可以说node是运行在服务器端V8引擎上的Ja ...

  10. SpringBoot系列: Eclipse+Maven环境准备

    这个链接比我写得更全面, http://tengj.top/2018/01/01/maven/ =============================20190115补充: maven 的一些插件 ...