如何使用REGEX解析逗号和换行符

时间:2019-11-07 17:00:54

标签: java regex csv parsing

我有一个csv文件,该文件的格式设置为一定值后有新行。看起来像这样:

Value1, Value2, Value3, Value4(/ n) "Value5", "Value 6", "Value 7"

如您所见,value4value5之间没有逗号分隔符。我试过测试array.split(\n)是否会创建一个字符串数组来定义新行,但是最终看起来像这样:

Value1, Value2, Value3, Value4"Value5", "Value6", "Value7"

我有这个case块,它确定分隔符的类型并对该字符执行拆分:

String[] recordValues;

        switch (fileType) {
            case "COMMA_DELIMITED":
                recordValues = record.split(",(?=(?:[^\"]*\"[^\"]*\")*[^\"]*$)");

我希望从以下结果看最终结果: Value1, Value2, Value3, Value4"Value5", "Value6", "Value7"

对此:Value1, Value2, Value3, Value4, "Value5", "Value6", "Value7"

很抱歉,这似乎是一个很简单的问题,我有点困惑。

2 个答案:

答案 0 :(得分:0)

Java中的拆分是通过指定正则表达式完成的,因此您可以自由地拆分一个或另一个字符。

您的正则表达式可能如下所示:

array.split("\n|,");

答案 1 :(得分:0)

假设您的意思是“ \ n”(您的示例是/ n),那么这个将对您有用:

String test = "Value1, Value2, Value3, Value4\n \"Value5\", \"Value 6\", \"Value 7\"";
String[] values = test.split(",|\n");
System.out.println(java.util.Arrays.deepToString(values));