簡體   English   中英

我如何使用 REGEX 來解析逗號和換行符

[英]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"

如您所見, 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"

如果這似乎是一個相當簡單的問題,我深表歉意,我有點難過。

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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM