温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

java后台怎么利用Pattern提取所需字符

发布时间:2022-01-11 15:15:59 来源:亿速云 阅读:162 作者:iii 栏目:开发技术

这篇文章主要讲解了“java后台怎么利用Pattern提取所需字符”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“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提取所需字符这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI