我有此csv文件,该文件的格式设置为一定值后有新行。看起来像这样:Value1, Value2, Value3, Value4
(/ n)"Value5", "Value 6", "Value 7"
如您所见,在value4
和value5
之间没有逗号分隔符。我试过测试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/