zoukankan      html  css  js  c++  java
  • 黑马程序员java笔记之七正则表达式

     正则表达式:符合一定规则的表达式       

                 特点:用于一些特定的符号表示一些代码。这样简化书,学习特殊符号的使用

                 作用:用于专门操作字符串
                 弊端:符号定义越多,正则越长,阅读性较差
                 好处:可以简化对字符串的复杂操作
    API解释:

           指定为字符串的正则表达式必须首先被编译为此类的实例。然后,可将得到的模式用于创建 Matcher 对象,依照正则表达式,该对象可以与任意字符序列匹配。执行匹配所涉及的所有状态都驻留在匹配器中,所以多个匹配器可以共享同一模式。

    具体操作功能:

        1.    匹配: String mathes方法。用规则匹配整个字符串,只要有一处不符合规则,就匹配结束。
                 public boolean matches(String regex)
                   告知此字符串是否匹配给定的正则表达式。 
                   String  qq=”df”;
                   String  regex=”[1-9][0-9]{4,14}”
                   Boolean  flag=qq.mathces(regex)
                   X?    X,一次或一次也没有
                  X*    X,零次或多次
                  X+    X,一次或多次
                  X{n}    X,恰好 n 次
                  X{n,}    X,至少 n 次
                  X{n,m}    X,至少 n 次,但是不超过 m 次
         2.    切割 String split()方法

    1. <span style="font-size:18px;">    public class  RegexDemo  
    2.                   {  
    3.                      public static void main(String[] args)  
    4.                       {  
    5.                           splitDemo("abcdfadffdssfsssfsdfd""(.)\\0");//按照叠词完成切割。为了可以让规则的结果被重用  
    6.               //可以讲规则封装到一个组,用()完成,组的出现都有编号。从1开始,想要使用已有的组可以通过,\n(就//是租的编号)  
    7.                       }  
    8.                       public static void  splitDemo(String str,String regex)  
    9.   
    10.                           {  
    11.                           String [] arr=str.split(regex);  
    12.                           for(String s:arr){  
    13.                     System.out.println(s);  
    14.                           }  
    15.              }  
    16.     }</span>  


        3.替换: String replaceALL(xxx)

    1. <span style="font-size:18px;">      
    2.   public class RegexDemo  
    3.         {  
    4.            public static void main(String[] args)  
    5.            {  
    6.             //splitDemo("abcdfadffdssfssssssssssssssfsdfd", "(.)\\1+");  
    7.             String str="wefsdfs13213333333334234r"//  
    8.             replaceAllDemo(str, "(.)\\1{1}", &1"); //将重叠的字符替换成单个字母。zzzz--->z  
    9.         }  
    10.         public static void replaceAllDemo(String str,String reg,String newStr){  
    11.             str=str.replaceAll(reg, newStr);  
    12.             System.out.println(str);            
    13.         }  
    14.  }</span>  

         4,获取:将字符串中的符合规则的字串取出  
         操作步骤:

       1.将正则表达式封装成对象。
       2.让正则表达式和要操作的字符串相关联
       3.关联后,获取正则匹配引擎
       4.通过引擎对符合规则的字串进行操作。
       group()用于获取匹配后的结果
       ^ 行的开头 
       $ 行的结尾 
       \b 单词边界 
       \B 非单词边界 
       \A 输入的开头 
       \G 上一个匹配的结尾 
       \Z 输入的结尾,仅用于最后的结束符(如果有的话) 
       \z 输入的结尾 
    1. <span style="font-size:18px;">  public class RegexDemo{  
    2.              public static void main(String[] args) throws SecurityException, NoSuchMethodException,  
    3.           IllegalArgumentException, IllegalAccessException, InvocationTargetException  
    4.        {  
    5.         getDemo();  
    6.         }  
    7.          public static void getDemo(){  
    8.             String str="ming tian shi ge hao tian qi";  
    9.             String reg="\\b[a-z]{4}\\b";  
    10.             //将规则封装成对象  
    11.             Pattern p=Pattern.compile(reg);  
    12.             //让正则对象和要作用的字符串相关联。获取匹配器对象。  
    13.             Matcher m=p.matcher(str);  
    14.             System.out.println("matches:"+m.matches());//同一个匹配器,用同一个索引位  
    15.             while(m.find()){//循环查询,将规则作用到字符传声,并进行符合规则的查找  
    16.                 System.out.println(m.group());  
    17.                 System.out.println(m.start()+"....."+m.end());  
    18.             }  
    19.         }</span>  

    正则表达式(练习1)
         需求:
              将下列字符串转换
         到底用四种功能中的哪一个呢?或者那几个呢?
                 思路方式:
                              1.如果只想知道字符是否对错,使用匹配。
                              2.想要将已有的字符串变成另一个字符串,替换。
                              3.想要按照自定的方式将子妇产变成多个字符串,切割。
                              4.想要按照符合要求的字符串字串,获取。

    1. <span style="font-size:18px;">     public class RegexDemo{  
    2.          public static void main(String[] args)  
    3.              {  
    4.                getDemo();  
    5.               }  
    6.                public static void getDemo(){  
    7.            String  str="我....我.......要要要...........学..........习";  
    8.             str=str.replaceAll("\\.+""");//去点  
    9.             System.out.println(str);  
    10.             str=str.replaceAll("(.)\\1+""$1");//去掉叠词  
    11.             System.out.println(str);  
    12.               }  
    13. }</span>  

    正则表达式(练习2)
                            将ip地址进行地址段顺序的排序
                            按照字符串自然顺序,只要将他们每一段都是3位即可
                            1.按照每一段需要的最多的0进行补齐,那么每一段就会至少保证有3位
                            2.将每一段只保留3位。这样,所有的ip地址都是每一段3位。
                          

    1. <span style="font-size:18px;"public static void ipSort(){  
    2.     String ip = "192.68.3.124 102.49.23.013 10.10.11.10 2.2.21.2 8.109.10.30";            
    3.         ip = ip.replaceAll("(\\d+)","00$1");  //补充0  
    4.         System.out.println(ip);  
    5.         ip = ip.replaceAll("0*(\\d{3})","$1"); //替换  
    6.         System.out.println(ip);  
    7.         String[] arr = ip.split(" ");//分割  
    8.         TreeSet<String> ts = new TreeSet<String>()                
    9.         for(String s : arr) //遍历  
    10.         {  
    11.             ts.add(s);  
    12.         }  
    13.         for(String s : ts)  
    14.         {  
    15.             System.out.println(s.replaceAll("0*(\\d+)","$1"));  
    16.         }  
    17.    }  
    18. </span>  

    邮箱地址判断:
                    

    1. <span style="font-size:18px;">       public static void check(){  
    2.                                String mail = "abc12343@sina.com";  
    3.                                 mail = "223343341@1.1";  
    4.                                 String reg = "[a-zA-Z0-9_]+@[a-zA-Z0-9]+(\\.[a-zA-Z]+)+";//精确的匹配。  
    5.                                 reg = "\\w+@\\w+(\\.\\w+)+";//不太精确的匹配。  
    6.   
    7.                                 //mail.indexOf("@")!=-1  
    8.                          System.out.println(mail.matches(reg));  
    9.         }  
    10.   
    11. </span>  
  • 相关阅读:
    洛谷.3254.圆桌问题(最大流ISAP)
    BZOJ.2639.矩形计算(二维莫队)
    BZOJ.2724.[Violet 6]蒲公英(静态分块)
    BZOJ.4241.历史研究(回滚莫队 分块)
    BZOJ.4542.[HNOI2016]大数(莫队)
    SPOJ.COT2 Count on a tree II(树上莫队)
    BZOJ.3757.苹果树(树上莫队)
    洛谷.2325.[SCOI2005]王室联邦(贪心)
    BZOJ.1299.[LLH邀请赛]巧克力棒(博弈论 Nim)
    HDU.2516.取石子游戏(博弈论 Fibonacci Nim)
  • 原文地址:https://www.cnblogs.com/lixiaolun/p/2832761.html
Copyright © 2011-2022 走看看