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提取所需字符内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
深入理解Mybatis中的resultType和resultMap
这篇文章给大家介绍了mybatis中的resultType和resultMap的用法实例讲解,MyBatis中在查询进行select映射的时候,返回类型可以用resultType,也可以用resultMap,至于两种用法区别,通过本文一起学习吧2016-09-09SpringBoot Filter修改返回内容,解决请求卡死200的错误
这篇文章主要介绍了SpringBoot Filter修改返回内容,解决请求卡死200的错误问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-07-07java 发送带Basic Auth认证的http post请求实例代码
下面小编就为大家带来一篇java 发送带Basic Auth认证的http post请求实例代码。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2016-11-11
最新评论