文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Java正则表达式(匹配、切割、替换、获取)等方法

2023-05-31 11:51

关注

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

作用:用于专门操作字符串

特点:用于一些特定的符号来表示一些代码操作,这样就简化书写,主要是学习一些特殊符号的使用

好处:可以简化对字符串的复杂操作。

弊端:符号定义越多,正则越长,阅读性越差

具体操作:

匹配:String matches方法

用规则匹配所有的字符串,只要有一个不符合,则匹配结束。

切割:String sqlit();

替换:replaceAll();

获取:将字符串中的符合规则的子串取出。

操作步骤:

首先,将正则表大式封装成对象。

然后,将正则对象和要操作的字符吕相关联。

接下来,关联后,获取正则匹配的引擎

最后,通过引擎对符合规则的子串进行操作。

public class RegexDemo {    public static void main(String[] args){   //checkQQ_1();   //checkqq();   //Demo();   //checkTel();   //splitDemo();//切割   String str="oadi3298324892adkal309290kdoda300000";//将字符串中的数组替换成#   replaceAllDemo(str,"\\d{7,}","#");   String str1="aadkkkaooelliwoonbvxkksoll";//将叠词替换成&   replaceAllDemo(str1,"(.)\\1+","&");   String str2="aadkkkaooelliwoonbvxkksoll";//将叠词的字符串替的确成单个字母   replaceAllDemo(str1,"(.)\\1+","$1");//想要获取组的符号$,$1就是拿前面的这个规则中的组  }    public static void checkQQ_1(){   String qq="a12345455";   int len=qq.length();   if(len>=5&&len<=15){    if(!qq.startsWith("0")){ //    char[] arr=qq.toCharArray();//把字符串转换成数组类型 //    boolean flag=true; //    for(int x=0;x<arr.length;x++){ //     if(!(arr[x]>='0'&&arr[x]<='9')){ //     flag=false; //     break; //     } //    } //    if(flag){ //     System.out.println("qq:"+qq); //    } //    else{ //     System.out.println("出现非法字符"); //    }     try {      long l=Long.parseLong(qq);      System.out.println("qq:"+l);     } catch (Exception e) {      System.out.println("出现非法字符");     }         }    else{     System.out.println("不可以以0开头");    }   }  }      public static void checkqq(){   String qq="1882345";   String regex="[1-9]\\d{4,14}";//这是正则表达式的规则   Boolean flag=qq.matches(regex);   if(flag){      System.out.println(qq+"...is ok");   }else{    System.out.println(qq+"...is not ok");   }  }      public static void Demo(){   String str="c";   String reg="[bcd][a-zA-Z]\\d";//\\d表示数字:[0-9]   //表示打头是字母,后面全是数字,用这个规则匹配所有的字符,一旦有一个不是,就会报错,   //如果是\d*,表示数字出现的次数是零次或多次   boolean b=str.matches(reg);   System.out.println(b);     }      public static void checkTel(){   String tel="13900008792";   String telReg="1[358]\\d{9}";   System.out.println(tel.matches(telReg));  }    public static void splitDemo(){   String str="zhangsan lisi wangxu";   String reg=" +";//按逗号,空格切,切割的原理找到有,然后就去切   //上面的加号就是只切一次空格,完了之后把后面的连接起来。还要注要.是一个特殊符号   //不能用.去切,我们可以用转义。应该是这样String reg="\\."   //如果要支切\\,如(c:\\abc\\a.txt),我们可以这样定义String reg="\\\\"   //按照叠词完成切割sqltDemo("ddkdakfdssieowor","(.)\\1)");其中的.表示任意字符,\1表示匹配前一个字符   //如果是ddd ssss ttttt这种的话,就在后面弄个"+",就是"(.)\\1+)" ,那个"+"是一个或多个的意思      String [] arr=str.split(reg);   for(String s:arr){    System.out.println(s);   }  }      public static void replaceAllDemo(String str,String reg,String newStr){      str=str.replaceAll(reg, newStr);      System.out.println(str);  }   } 

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 资料下载
  • 历年真题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯