>>分享Java编程技术,对《Java面向对象编程》等书籍提供技术支持 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 22845 个阅读者 刷新本主题
 * 贴子主题:  正则表达式【匹配非字母和数字】 回复文章 点赞(0)  收藏  
作者:flybird    发表时间:2021-08-01 07:37:42     消息  查看  搜索  好友  邮件  复制  引用

使用java的正则匹配之前要记得导包

import java.util.regex.Matcher;
import java.util.regex.Pattern;


1.使用正则判断是否有数字、字母
public static void main(String[] args) {
        System.out.println(containsNum("111"));
        System.out.println(containsLetter("aaa"));
        System.out.println(containsNumOrLetter("aaa"));
    }
//判断是否含有字母
    public static boolean containsLetter(String str) {
        String patt="";
        Pattern r = Pattern.compile(patt);
        Matcher matcher = r.matcher(str);
        return matcher.find();
    }
//判断是否含有数字
    public static boolean containsNum(String str) {
        String patt="[0-9]";
        Pattern r = Pattern.compile(patt);
        Matcher matcher = r.matcher(str);
        return matcher.find();
    }
//判断是否含有数字或字母
    public static boolean containsNumOrLetter(String str) {
        String patt="[0-9|a-z|A-Z]";
        Pattern r = Pattern.compile(patt);
        Matcher matcher = r.matcher(str);
        return matcher.find();
    }

2.那如果是判断是不含有字母或数字的正则怎么写呢?

   public static void main(String[] args) {
        System.out.println(containsNoNum("111"));
        System.out.println(containsNoLetter("aaa"));
        System.out.println(containsNoNumOrLetter("aaa"));
    }

    public static boolean containsNoLetter(String str) {
        String patt="[^a-z]";
        Pattern r = Pattern.compile(patt);
        Matcher matcher = r.matcher(str);
        return matcher.find();
    }

    public static boolean containsNoNum(String str) {
        String patt="[^0-9]";
        Pattern r = Pattern.compile(patt);
        Matcher matcher = r.matcher(str);
        return matcher.find();
    }

    public static boolean containsNoNumOrLetter(String str) {
        String patt="[^0-9|a-z|A-Z]";
        Pattern r = Pattern.compile(patt);
        Matcher matcher = r.matcher(str);
        return matcher.find();
    }

3.根据上面的正则来写一个比较版本号的方法


    public static void main(String[] args) {
        System.out.println(compareVersion("1.3_bc", "1.3_b"));
    }


    public static String compareVersion(String version1, String version2) {

        //忽略大小写,只保留数字和字母和点
        String v1 = version1.toLowerCase().replaceAll("[^0-9|a-z|.]", "");
        String v2 = version2.toLowerCase().replaceAll("[^0-9|a-z|.]", "");
        //按点来切割
        String[] arr1 = v1.split("\\.");
        String[] arr2 = v2.split("\\.");
        int len = arr1.length > arr2.length ? arr2.length : arr1.length;

        //正则判断是否含有字母
        String patt = "";
        Pattern r = Pattern.compile(patt);
        int i = 0;
        do {
            Matcher m1 = r.matcher(arr1[i]);
            Matcher m2 = r.matcher(arr2[i]);

            boolean flag = false;
            //判断是否含有字母
            if (m1.find() && m2.find()) {//如果都含有字母
                //先比较数字
                String num1 = arr1[i].substring(0, m1.start());
                String num2 = arr2[i].substring(0, m2.start());
                if (Integer.parseInt(num1) > Integer.parseInt(num2)) {
                    return version1;
                } else if (Integer.parseInt(num1) < Integer.parseInt(num2)) {
                    return version2;
                }
                //再比较含有字母的字符串
                String str1 = arr1[i].substring(m1.start());
                String str2 = arr2[i].substring(m2.start());
                if (str1.compareTo(str2) > 0)
                    return version1;
                else if (str1.compareTo(str2) < 0)
                    return version2;
            } else if ((flag = m1.find()) || m2.find()) {//如果只是其中一个含有字母
                String vContains = flag ? arr1[i] : arr2[i];
                String vOther = flag ? arr2[i] : arr1[i];
                //先比较数字
                String num1 = vContains.substring(0, flag ? m1.start() : m2.start());
                String num2 = vOther;
                if (Integer.parseInt(num1) > Integer.parseInt(num2)) {
                    return version1;
                } else if (Integer.parseInt(num1) < Integer.parseInt(num2)) {
                    return version2;
                }
                return flag ? version1 : version2;
            } else {//如果都不含有字母,则直接比较数字
                if (Integer.parseInt(arr1[i]) > Integer.parseInt(arr2[i])) {
                    return version1;
                } else if (Integer.parseInt(arr1[i]) < Integer.parseInt(arr2[i])) {
                    return version2;
                }
            }
        } while (++i < len);

        //以上判断都没有结果则返回数组 长度较长的那个版本
        return arr1.length > arr2.length ? version1 : version2;
    }

————————————————
原文链接:https://blog.csdn.net/a_hui_tai_lang/article/details/81350422


程序猿的技术大观园:www.javathinker.net
  Java面向对象编程-->数据类型
  JavaWeb开发-->在Web应用中访问Web服务
  JSP与Hibernate开发-->立即检索和延迟检索策略
  Java网络编程-->非阻塞通信
  精通Spring-->计算属性和数据监听
  Vue3开发-->虚拟DOM和render()函数
   JAVA进阶之IO模型深入解析
  Java并发编程的总结与思考
  java.util.logging.Logger使用详解
  Java 语言中十大“坑爹”功能!
  十分钟带你搞懂 Java AQS 核心设计与实现!
  JDK14的新特性
  请求大佬们的帮助
  Java并发之volatile关键字内存可见性问题
  NoClassDefFoundError和ClassNotFoundException的区别
  Java设计模式:传输对象模式
  Java 入门实用代码:从 List列表中 截取子列表
  Java 入门实用代码:取最大和最小值
  Java入门实用代码:查找字符串最后一次出现的位置
  中国有多少程序员?现在还值得学java吗?
  jdbc连接各种数据库代码
  更多...
 IPIP: 已设置保密
树形列表:   
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。