首頁  >  文章  >  Java  >  Java中使用Scanner()讀取CSV檔案時如何正確處理空格?

Java中使用Scanner()讀取CSV檔案時如何正確處理空格?

Barbara Streisand
Barbara Streisand原創
2024-10-25 16:36:26847瀏覽

How to Handle Spaces Correctly When Reading CSV Files with Scanner() in Java?

使用 Scanner() 讀取 CSV

使用 Java 的 Scanner 類別讀取 CSV 檔案時,正確處理空格至關重要。此處描述的問題(其中帶有空格的文字被移動到下一行)是由掃描器的預設行為引起的。

預期行為:

CSV 檔案通常包含欄位帶有空格,例如位址。解析時,每個欄位都應被捕獲為一個單元,即使它包含空格。

實際行為:

預設情況下,Scanner 使用空格作為分隔符,這表示它將空格解釋為字段分隔符。因此,任何帶有空格的文字都會分成多個欄位並放置在單獨的行中。

解決方案:

要解決此問題,您可以使用 Scanner 的 useDelimiter 方法指定不同的分隔符號。由於 CSV 檔案通常使用逗號作為欄位分隔符,因此您可以使用以下程式碼:

<code class="java">Scanner inputStream = new Scanner(file).useDelimiter(",");</code>

這將指示 Scanner 將逗號視為欄位分隔符,從而保留帶有空格的欄位的完整性。

範例:

使用此更正後的程式碼,問題中提供的CSV 資料將解析如下:

first,last,email,address 1, address 2
john,smith,[email&#160;protected],123 St. Street,
Jane,Smith,[email&#160;protected],4455 Roger Cir,apt 2

每個字段,包括帶有空格的字段,將被捕獲為單個單元,從而產生所需的輸出。

以上是Java中使用Scanner()讀取CSV檔案時如何正確處理空格?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn