中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java后臺怎么利用Pattern提取所需字符

發布時間:2022-01-11 15:15:59 來源:億速云 閱讀:162 作者:iii 欄目:開發技術

這篇文章主要講解了“java后臺怎么利用Pattern提取所需字符”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“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提取所需字符這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    镇雄县| 通渭县| 清远市| 洪洞县| 嘉兴市| 余干县| 平乡县| 库尔勒市| 吉木萨尔县| 杭锦旗| 格尔木市| 涡阳县| 故城县| 安仁县| 同心县| 荥阳市| 郯城县| 武威市| 金平| 明星| 天镇县| 西乌珠穆沁旗| 西乌| 军事| 青铜峡市| 通州区| 彭泽县| 桦南县| 屏边| 横山县| 正阳县| 文登市| 苏尼特右旗| 营口市| 通江县| 宁波市| 疏附县| 垦利县| 略阳县| 阜新市| 大安市|