欢迎您访问新疆栾骏商贸有限公司,公司主营电子五金轴承产品批发业务!
全国咨询热线: 400-8878-609

新闻资讯

常见问题

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

作者:用户投稿2026-01-11 06:00:43
目录
  • 写在处理问题的前面
  • 遇到的问题,如何提取?
    • 1.首先进行简单测试
    • 2.项目内容测试
    • 3.进行实操
  • 附: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);
      

      总结