首頁 > Java > java教程 > 主體

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

Barbara Streisand
發布: 2024-10-25 16:36:26
原創
858 人瀏覽過

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中文網其他相關文章!

來源:php
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!