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

网友投稿 393 2022-09-04


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

目录写在处理问题的前面遇到的问题,如何提取?1.首先进行简单测试2.项目内容测试3.进行实操附:java Pattern正则获取大括号中内容总结

写在处理问题的前面

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

遇到的问题,如何提取?

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

1.首先进行简单测试

String str = "{abc{def:}deftfha}";

Pattern p=Pattern.compile("\\{(\\wSnYHfeDyv+)\\:");

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 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);

总结


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Python 枚举(python代码大全)
下一篇:Python3实用编程技巧进阶二
相关文章

 发表评论

暂时没有评论,来抢沙发吧~