首页  >  文章  >  Java  >  Java中使用Scanner()读取CSV文件时如何正确处理空格?

Java中使用Scanner()读取CSV文件时如何正确处理空格?

Barbara Streisand
Barbara Streisand原创
2024-10-25 16:36:26852浏览

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