java后臺(tái)如何利用Pattern提取所需字符詳解
寫(xiě)在處理問(wèn)題的前面
由于項(xiàng)目功能迭代,導(dǎo)致原來(lái)的頁(yè)面當(dāng)中ID命名規(guī)則,與當(dāng)前命名規(guī)則不同(ps:既然要用到原來(lái)的東西,為什么在設(shè)計(jì)的時(shí)候沒(méi)有考慮到兼容的問(wèn)題,無(wú)語(yǔ)),所以需要將原來(lái)的所有ID提取出來(lái)。
遇到的問(wèn)題,如何提???
查找了許多方法之后,感覺(jué)使用Pattern提取比較符合需求。于是開(kāi)始嘗試。
1.首先進(jìn)行簡(jiǎn)單測(cè)試
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)); }
好的沒(méi)問(wèn)題,提取正常。于是將所需提取的一部分字符串拿出來(lái)進(jìn)行測(cè)試。
2.項(xiàng)目?jī)?nèi)容測(cè)試
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)); }
問(wèn)題來(lái)了,沒(méi)有提取到任何內(nèi)容。那試試只提取EquipmentID當(dāng)中的字符呢,測(cè)試沒(méi)問(wèn)題。問(wèn)題就在正則匹配上了。(\\w+)只適用于截取文字部分,改為(.*),ok,可以正常截取SSC_FZ_DQ#MJ23JZ_FZ_CZ_CZGX#YL#SBBM這部分了。
3.進(jìn)行實(shí)操
建立數(shù)據(jù)庫(kù)連接。
public class CopyOracle2MySQL1 { /** * 源數(shù)據(jù)庫(kù),目標(biāo)數(shù)據(jù)庫(kù)的連接配置 */ 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 { // 創(chuàng)建到兩個(gè)數(shù)據(jù)庫(kù)的連接 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 { // 人工輸入各表名(需要保證順序,以確保有外鍵的表在主表之后插入數(shù)據(jù)) importTable(connDest, "APP_WGADDATA","qtsc_jk_scjkzttxx"); } finally { // 自動(dòng)關(guān)閉數(shù)據(jù)庫(kù)資源 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); } // 先計(jì)算目標(biāo)數(shù)據(jù)庫(kù)的PreparedStatement的SQL語(yǔ)句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(); }
測(cè)試結(jié)果發(fā)現(xiàn),在所有符合規(guī)則的前期下進(jìn)行提取,發(fā)現(xiàn),自動(dòng)匹配到了最后一個(gè)",“UnitName”,很顯然又是規(guī)則的問(wèn)題,于是將(.)改為(.?)問(wèn)題解決。
附:JAVA Pattern正則獲取大括號(hào)中內(nèi)容
利用正則表達(dá)式獲取字符串中想要的值:
獲取符串場(chǎng)景: 你好呀(嘻嘻)
我需要獲取“嘻嘻” 該如何獲取呢?
1.通過(guò)正則表達(dá)式獲?。?/p>
String str = "你好呀(嘻嘻)"; Pattern p = Pattern.compile("\\(([^\\)]+)"); Matcher matcher = p.matcher(str); if (matcher.find() && matcher.groupCount() >= 1){ System.out.println(matcher.group(1)); }
2.通過(guò)字符截取獲?。?/p>
String str = "你好呀(嘻嘻)"; String xixi = str.substring(str.indexOf("(") + 1, str.indexOf(")")); System.out.println(xixi);
總結(jié)
到此這篇關(guān)于java后臺(tái)如何利用Pattern提取所需字符的文章就介紹到這了,更多相關(guān)java用Pattern提取所需字符內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java 實(shí)現(xiàn)Comparable接口排序,升序、降序、倒敘
這篇文章主要介紹了java 實(shí)現(xiàn)Comparable接口排序,升序、降序、倒敘,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08IDEA SpringBoot 項(xiàng)目配置Swagger2的詳細(xì)教程
這篇文章主要介紹了IDEA SpringBoot 項(xiàng)目配置Swagger2的詳細(xì)教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11Java中Array、List、ArrayList的區(qū)別及說(shuō)明
這篇文章主要介紹了Java中Array、List、ArrayList的區(qū)別及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07基于UDP協(xié)議實(shí)現(xiàn)聊天系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了基于UDP協(xié)議實(shí)現(xiàn)聊天系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04Web容器啟動(dòng)過(guò)程中如何執(zhí)行Java類(lèi)
這篇文章主要介紹了Web容器啟動(dòng)過(guò)程中如何執(zhí)行Java類(lèi),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10Java正則驗(yàn)證正整數(shù)的方法分析【測(cè)試可用】
這篇文章主要介紹了Java正則驗(yàn)證正整數(shù)的方法,結(jié)合實(shí)例形式對(duì)比分析了java針對(duì)正整數(shù)的驗(yàn)證方法及相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-08-08@TransactionalEventListener的使用和實(shí)現(xiàn)原理分析
這篇文章主要介紹了@TransactionalEventListener的使用和實(shí)現(xiàn)原理分析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12