我有这个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"
如果这看起来是一个相当简单的问题,我很抱歉,我有点困惑。
发布于 2019-11-08 01:05:50
Java中的拆分是通过指定正则表达式来完成的,因此您可以自由地按一个或另一个字符拆分。
您的正则表达式可能如下所示:
array.split("\n|,");发布于 2019-11-08 01:14:06
假设您指的是'\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));https://stackoverflow.com/questions/58753689
复制相似问题