本篇文章小编给大家分享一下java后台利用Pattern提取所需字符代码解析,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
1.首先进行简单测试
String str = "{abc{def: }deftfha }";
Pattern p=Pattern.compile("{(w+): ");
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);