使用 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中文网其他相关文章!