4

我想使用 parsingMethod 解析文件的行

测试.csv

 Frank George,Henry,Mary / New York,123456
,Beta Charli,"Delta,Delta Echo
", 25/11/1964, 15/12/1964,"40,000,000.00",0.0975,2,"King, Lincoln ",Alpha

这是我读行的方式

 public static void main(String[] args) throws Exception {


        File file = new File("C:\\Users\\test.csv");
        BufferedReader reader = new BufferedReader(new FileReader(file));   
        String line2;
        while ((line2= reader.readLine()) !=null) {
            String[] tab = parsingMethod(line2, ",");
            for (String i : tab) {
                System.out.println( i );
            }
        }


    }

    public static String[] parsingMethod(String line,String parser) {

        List<String> liste = new LinkedList<String>();
        String patternString ="(([^\"][^"+parser+ "]*)|\"([^\"]*)\")" +parser+"?";
        Pattern pattern = Pattern.compile(patternString);
        Matcher matcher =pattern.matcher(line);

        while (matcher.find()) {
            if(matcher.group(2) != null){
                liste.add(matcher.group(2).replace("\n","").trim());
            }else if(matcher.group(3) != null){
                liste.add(matcher.group(3).replace("\n","").trim());
            }       
        }

        String[] result = new String[liste.size()];
        return liste.toArray(result);
    }
}

输出 :

Frank George
Henry
Mary / New York
123456

Beta Charli
Delta
Delta Echo
"
25/11/1964
15/12/1964
40,000,000.00
0.0975
2
King
Lincoln
"
Alpha
Delta
Delta Echo

我想删除这个“,任何人都可以帮助我改进我的模式。


预期产出

Frank George
Henry
Mary / New York
123456
Beta Charli
Delta
Delta Echo
25/11/1964
15/12/1964
40,000,000.00
0.0975
2
King
Lincoln
Alpha
Delta
Delta Echo

第 3 行的输出

25/11/1964
15/12/1964

40
000
000.00


0.0975
2

King
Lincoln
4

3 回答 3

2

您的代码没有正确编译,但这是由于一些"没有被转义造成的。

但这应该可以解决问题:

String patternString = "(?:^.,|)([^\"]*?|\".*?\")(?:,|$)";
Pattern pattern = Pattern.compile(patternString, Pattern.MULTILINE);

(?:^.,|)是一个非捕获组,匹配行首的单个字符

([^\"]*?|\".*?\")是一个捕获组,匹配除“或”之间的任何内容之外的所有内容

(?:,|$)是匹配行尾或逗号的非捕获组。

注意:^并且$仅在使用 Pattern.MULTILINE 标志编译模式时按说明工作

于 2013-05-15T09:55:45.340 回答
1

我无法重现您的结果,但我想也许您想将引号从第二个捕获的组中删除,如下所示:

"(([^\"][^"+parser+ "]*)|\"([^\"]*))\"" +parser+"?"

编辑:对不起,这行不通。也许您还想让^\"第一组中的任意数量,如下所示:(([^,\"]*)|\"([^\"]*)\"),?

于 2013-05-15T09:16:47.003 回答
1

正如我所看到的,这些行是相关的,所以试试这个:

    public static void main(String[] args) throws Exception {

        File file = new File("C:\\Users\\test.csv");
        BufferedReader reader = new BufferedReader(new FileReader(file));
        StringBuilder line = new StringBuilder();
        String lineRead;
        while ((lineRead = reader.readLine()) != null) {
            line.append(lineRead);
        }
        String[] tab = parsingMethod(line.toString());
        for (String i : tab) {
            System.out.println(i);
        }


    }

    public static String[] parsingMethod(String line) {

        List<String> liste = new LinkedList<String>();
        String patternString = "(([^\"][^,]*)|\"([^\"]*)\"),?";
        Pattern pattern = Pattern.compile(patternString);
        Matcher matcher = pattern.matcher(line);

        while (matcher.find()) {
            if (matcher.group(2) != null) {
                liste.add(matcher.group(2).replace("\n", "").trim());
            } else if (matcher.group(3) != null) {
                liste.add(matcher.group(3).replace("\n", "").trim());
            }
        }

        String[] result = new String[liste.size()];
        return liste.toArray(result);
    }

输出:

Frank George
Henry
Mary / New York
123456
Beta Charli
Delta,Delta Echo
25/11/1964
15/12/1964
40,000,000.00
0.0975
2
King, Lincoln
Alpha

作为 Delta,Delta Echo 在引用中,这应该出现在同一行!像国王,林肯一样

于 2013-05-15T12:08:55.610 回答