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提取所需字符內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: