您好,登錄后才能下訂單哦!
這篇文章主要講解了“java后臺怎么利用Pattern提取所需字符”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“java后臺怎么利用Pattern提取所需字符”吧!
由于項目功能迭代,導致原來的頁面當中ID命名規則,與當前命名規則不同(ps:既然要用到原來的東西,為什么在設計的時候沒有考慮到兼容的問題,無語),所以需要將原來的所有ID提取出來。
查找了許多方法之后,感覺使用Pattern提取比較符合需求。于是開始嘗試。
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)); }
好的沒問題,提取正常。于是將所需提取的一部分字符串拿出來進行測試。
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這部分了。
建立數據庫連接。
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”,很顯然又是規則的問題,于是將(.)改為(.?)問題解決。
利用正則表達式獲取字符串中想要的值:
獲取符串場景: 你好呀(嘻嘻)
我需要獲取“嘻嘻” 該如何獲取呢?
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提取所需字符這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。