使用 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 protected],123 St. Street, Jane,Smith,[email protected],4455 Roger Cir,apt 2
每個字段,包括帶有空格的字段,將被捕獲為單個單元,從而產生所需的輸出。
以上是Java中使用Scanner()讀取CSV檔案時如何正確處理空格?的詳細內容。更多資訊請關注PHP中文網其他相關文章!