簡體   English   中英

讀取帶換行符的轉義java文件

[英]Reading java file with escape characters for newline

我有一個需要導出到數據庫(Vertica)的Unicode文件。 列分隔符是CTRL + B,記錄分隔符是換行符(\\ n)。 只要列值中有換行符,CTRL + A就會用作轉義字符。

當我使用BufferedReader.readLine()讀取此文件時,ID為2和4的記錄將被讀取為兩個記錄。 而我想將它們作為輸出中給出的單個整體記錄來閱讀。

這是示例輸入文件。 | 代表CTRL + B,^代表CTRL + A.

Input
ID|Name|Job Desc
----------------
1|xxxx|SO Job
2|YYYY|SO Careers^
Job
3|RRRRR|SO
4|ZZZZ^
 ZZ|SO Job
5|AAAA|YU

Output:
ID|Name|Job Desc
----------------
1|xxxx|SO Job
2|YYYY|SO Careers Job
3|RRRRR|SO
4|ZZZZ ZZ|SO Job
5|AAAA|YU

該文件很大,所以我不能使用StringEscapeUtils。 有什么建議嗎?

您可以將Scanner與自定義分隔符一起使用。 我使用的分隔符設置為匹配\\n匹配\\n \\\n (其中\代表CTRL+A ):

try {
    PrintWriter writer = new PrintWriter("dboutput.txt");
    Scanner sc = new Scanner(new File("dbinput.txt"));
    sc.useDelimiter(Pattern.compile("^(?!.*(\\u0001\\n)).*\\n$"));
    while (sc.hasNext()) {
        writer.println(sc.next());
    }
    scanner.close();
    writer.close();
} catch (FileNotFoundException e) {
   e.printStackTrace();
} 

蒂姆對他的回答部分正確。 但是,它仍然無法解決CTRL + A轉義的換行符。

這是我的解決方案(由Tim回答)

File f = new File("C:\\Users\\SV7104\\Desktop\\sampletest.txt");
Scanner sc = new Scanner(f).useDelimiter(Pattern.compile("\\s*\\u0002\\n\\s*"));
            while (sc.hasNext()) {
                System.out.print(1);
                System.out.println(sc.next().toString().replaceAll("\\u0001\\n", " "));

            }

如果還有其他一些有效的方法,我很想知道這一點。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

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