java后台如何利用Pattern提取所需字符详解

 更新时间:2022年01月11日 14:10:17   作者:爬坑的小bugger  
这篇文章主要给大家介绍了关于java后台如何利用Pattern提取所需字符的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

写在处理问题的前面

由于项目功能迭代,导致原来的页面当中ID命名规则,与当前命名规则不同(ps:既然要用到原来的东西,为什么在设计的时候没有考虑到兼容的问题,无语),所以需要将原来的所有ID提取出来。

遇到的问题,如何提取?

查找了许多方法之后,感觉使用Pattern提取比较符合需求。于是开始尝试。

1.首先进行简单测试

String str = "{abc<icon>{def:</icon>}deftfh<icon>a</icon>}";
Pattern p=Pattern.compile("<icon>\\{(\\w+)\\:</icon>");
Matcher m=p2.matcher(str2);
        while(m.find()){
            System.out.println(m.group(1));
            }

好的没问题,提取正常。于是将所需提取的一部分字符串拿出来进行测试。

2.项目内容测试

String str = "\"EquipmentID\":\"SSC_FZ_DQ#MJ23JZ_FZ_CZ_CZGX#YL#SBBM\",";
Pattern p=Pattern.compile("\"EquipmentID\":\"(\\w+)\",");
Matcher m=p2.matcher(str2);
        while(m.find()){
            System.out.println(m.group(1));
            }

问题来了,没有提取到任何内容。那试试只提取EquipmentID当中的字符呢,测试没问题。问题就在正则匹配上了。(\\w+)只适用于截取文字部分,改为(.*),ok,可以正常截取SSC_FZ_DQ#MJ23JZ_FZ_CZ_CZGX#YL#SBBM这部分了。

3.进行实操

建立数据库连接。

public class CopyOracle2MySQL1 {
    /**
     * 源数据库,目标数据库的连接配置
      */
    private final String DEST_MYSQL_JDBC_URL = ;
    private final String SOURCE_JDBC_URL = "";
    private final String SOURCE_JDBC_USER = "";
    private final String SOURCE_JDBC_PASSWORD = "";

    public void startImport() throws Exception {
        // 创建到两个数据库的连接
        Class.forName("com.mysql.jdbc.Driver");
        //Class.forName("oracle.jdbc.driver.OracleDriver");

        Connection connDest = DriverManager.getConnection(DEST_MYSQL_JDBC_URL);
        //Connection connSource = DriverManager.getConnection(SOURCE_JDBC_URL, SOURCE_JDBC_USER, SOURCE_JDBC_PASSWORD);

        try {

            // 人工输入各表名(需要保证顺序,以确保有外键的表在主表之后插入数据)
            importTable(connDest, "APP_WGADDATA","qtsc_jk_scjkzttxx");

        } finally {
            // 自动关闭数据库资源
            connDest.close();
            //connSource.close();
        }
    }

    private void importTable(Connection connDest, String oracleTableName,String mysqlTableName) throws Exception {

        Statement stmt = null;

        try {

            stmt = connDest.createStatement();
            String mysqlSql = "select ZTTNR from qtsc_jk_scjkzttxx qjs where qjs.ZTTID  = '0284fcbdcdbd4da3bdef78ed769515c6'";
            String mysqlSql1 = "select ZTTNR from qtsc_jk_scjkzttxx";
            ResultSet rs = stmt.executeQuery(mysqlSql1);

            Map<String, String> sbbmMap = new HashMap();
            while(rs.next()){
                String zttnr = rs.getString(1);
                //System.out.println(zttnr);
                Pattern p = Pattern.compile("\"EquipmentID\":\"(.*)\",\"UnitName\"");
                Matcher m=p.matcher(zttnr);
                while(m.find()){
                    System.out.println(m.group(1));

                }
                //System.out.println(sbbmMap);
            }

            // 先计算目标数据库的PreparedStatement的SQL语句z
            ResultSetMetaData rsmd = rs.getMetaData();

            rs.close();
        }catch (Exception e){

            e.printStackTrace();
        }
        finally {
            if(stmt != null) {
                stmt.close();
            }
        }
    }

    public static void main(String[] args) throws Exception {
        CopyOracle2MySQL1 ins = new CopyOracle2MySQL1();
        ins.startImport();
    }

测试结果发现,在所有符合规则的前期下进行提取,发现,自动匹配到了最后一个",“UnitName”,很显然又是规则的问题,于是将(.)改为(.?)问题解决。

附:JAVA Pattern正则获取大括号中内容

利用正则表达式获取字符串中想要的值:

获取符串场景: 你好呀(嘻嘻)

我需要获取“嘻嘻” 该如何获取呢?

1.通过正则表达式获取:

        String str = "你好呀(嘻嘻)";
        Pattern p = Pattern.compile("\\(([^\\)]+)");
        Matcher matcher = p.matcher(str);
        if (matcher.find() && matcher.groupCount() >= 1){
            System.out.println(matcher.group(1));
        }

2.通过字符截取获取:

        String str = "你好呀(嘻嘻)";
        String xixi = str.substring(str.indexOf("(") + 1, str.indexOf(")"));
        System.out.println(xixi);

总结

到此这篇关于java后台如何利用Pattern提取所需字符的文章就介绍到这了,更多相关java用Pattern提取所需字符内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java Collections的emptyList、EMPTY_LIST详解与使用说明

    Java Collections的emptyList、EMPTY_LIST详解与使用说明

    这篇文章主要介绍了Java Collections的emptyList、EMPTY_LIST详解与使用说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • 很多人竟然不知道Java线程池的创建方式有7种

    很多人竟然不知道Java线程池的创建方式有7种

    本文主要介绍了很多人竟然不知道Java线程池的创建方式有7种,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • mybatis如何根据表逆向自动化生成代码实例

    mybatis如何根据表逆向自动化生成代码实例

    逆向工程是一个专门为 MyBatis 框架使用者设计的代码生成器,可以根据数据库中的表字段名,自动生成 POJO 类,mapper 接口与 SQL 映射文件,这篇文章主要给大家介绍了关于mybatis如何根据表逆向自动化生成代码的相关资料,需要的朋友可以参考下
    2021-08-08
  • Mybatis逆向工程时失败问题及解决

    Mybatis逆向工程时失败问题及解决

    这篇文章主要介绍了Mybatis逆向工程时失败问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • MyBatis Plus实现一对多的查询场景的三种方法

    MyBatis Plus实现一对多的查询场景的三种方法

    MyBatis Plus提供了多种简便的方式来进行一对多子查询,本文主要介绍了MyBatis Plus实现一对多的查询场景的三种方法,具有一定的参考价值,感兴趣的可以了解一下
    2024-07-07
  • java加载属性配置properties文件的方法

    java加载属性配置properties文件的方法

    这篇文章主要介绍了java加载属性配置properties文件的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • IDEA搭建SpringBoot多模块聚合工程过程详解(多模块聚合工程)

    IDEA搭建SpringBoot多模块聚合工程过程详解(多模块聚合工程)

    这篇文章主要是介绍一下,如何在IDEA开发工具下,搭建一个基于SpringBoot的多模块聚合工程项目,本篇文章,将项目模块细分为几个子工程模块,在文中给大家详细介绍过,对IDEA搭建SpringBoot多模块聚合工程感兴趣的朋友一起看看吧
    2022-04-04
  • java开发中基于JDBC连接数据库实例总结

    java开发中基于JDBC连接数据库实例总结

    这篇文章主要介绍了java开发中基于JDBC连接数据库的方法,以实例形式较为详细的总结分析了Java使用JDBC的具体步骤与注意事项,并附带了一个完整实例加以说明,需要的朋友可以参考下
    2015-11-11
  • Java中常见的文件拷贝方式小结

    Java中常见的文件拷贝方式小结

    这篇文章主要为大家详细介绍了JAVA 四种拷贝文件的方式,分析一下他们对内存使用的方式和各自应用的场景,其实也是对之前学过的知识做一个回顾吧,快跟随小编一起学习起来吧
    2024-03-03
  • Java Chassis3过载状态下的快速失败解决分析

    Java Chassis3过载状态下的快速失败解决分析

    本文解密了Java Chassis 3快速失败相关的机制和背后故事,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2024-01-01

最新评论