正则表达式模式仅从字符串列表中获取特定部分

时间:2018-08-30 13:25:06

标签: java regex

由于我是Regex模式的新手,所以我想从下面提到的字符串列表中提取特定部分,并将其作为键值对存储在Map中。

示例:

List<String> ref3Path = new ArrayList<String>(); 
ref3Path.add("s3://REF3/ca209_040/ahshd.csv");
ref3Path.add("s3://REF3/ca209_040/grren.csv");
ref3Path.add("s3://REF3/ca209_030/aestyyuae.csv");

我只需要上面列表中的 ca209_040 aesae.csv ,并希望存储在地图中。

以下是我正在编写的用于比较列表和地图的代码:

public static void main(String[] args) {
    // TODO Auto-generated method stub

    MultiValuedMap<String, String> studyDomain = new ArrayListValuedHashMap<>();
    List<String> ref3Path = new ArrayList<String>(); 

    studyDomain.put("ca209_040", "czvv.csv");
    studyDomain.put("ca209_040", "efe.csv");
    studyDomain.put("ca209_030", "efef.csv");
    studyDomain.put("ca209_030", "hhhjd.csv");
    studyDomain.put("ca209_020", "rr.csv");
    studyDomain.put("ca209_020", "eghh.csv");

    ref3Path.add("s3://REF3/ca209_040/jlkjl.csv");
    ref3Path.add("s3://REF3/ca209_040/aesaehkhk.csv");
    ref3Path.add("s3://REF3/ca209_030/aesaedhd.csv");
    ref3Path.add("null");
    ref3Path.add("s3://REF3/ca209_020/aedae.csv");
    ref3Path.add("s3://REF3/ca209_020/aeqwee.csv");

    log.info("List of inbox: " +studyDomain);
    log.info("List of ref3 :" +ref3Path);

    rule1(studyDomain,ref3Path);
}

1 个答案:

答案 0 :(得分:0)

您可以使用简单的split函数来完成此操作。正则表达式模式过大了

注意:检查边界条件

scala> val arr = "s3://REF3/ca209_040/aesae.csv".split('/')
arr: Array[String] = Array(s3:, "", REF3, ca209_040, aesae.csv)

scala> arr(3)
res2: String = ca209_040

scala> arr(4)
res3: String = aesae.csv

在Java中

注意:检查边界条件

public class Demo {
    public static void main(String[] s) {
        String[] args = "s3://REF3/ca209_040/aesae.csv".split("/");
        System.out.println(args[3] + " ,  " + args[4]);
    }
}