[英]How can i use REGEX to parse commas as well as newline
我有這個 csv 文件,它的格式設置為在某個值之后有一個新行。 它看起來像這樣:
Value1, Value2, Value3, Value4
值 2、值 3、值 4 (/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"
如果這似乎是一個相當簡單的問題,我深表歉意,我有點難過。
Java 中的拆分是通過指定正則表達式完成的,因此您可以自由地按一個或另一個字符進行拆分。
您的正則表達式可能如下所示:
array.split("\n|,");
假設你的意思是'\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));
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.