我有此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"

如果这似乎是一个很简单的问题,我深表歉意。

最佳答案

假设您的意思是“ \ in”(您的示例是/ 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));

关于java - 如何使用REGEX解析逗号和换行符,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/58753689/

10-12 17:18