首页 > 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学习者快速成长!