Home > Java > javaTutorial > How to Handle Spaces Correctly When Reading CSV Files with Scanner() in Java?

How to Handle Spaces Correctly When Reading CSV Files with Scanner() in Java?

Barbara Streisand
Release: 2024-10-25 16:36:26
Original
1029 people have browsed it

How to Handle Spaces Correctly When Reading CSV Files with Scanner() in Java?

Read CSV with Scanner()

When reading CSV files using Java's Scanner class, it's crucial to handle spaces correctly. The issue described here, where text with spaces gets moved to the next line, arises from the default behavior of Scanner.

Expected Behavior:

CSV files often contain fields with spaces, such as addresses. When parsed, each field should be captured as a single unit, even if it contains spaces.

Actual Behavior:

By default, Scanner uses whitespace as a delimiter, meaning that it interprets spaces as field separators. Consequently, any text with spaces gets split into multiple fields and placed on separate lines.

Solution:

To resolve this issue, you can use the useDelimiter method of Scanner to specify a different delimiter. Since CSV files typically use commas as field separators, you can use the following code:

<code class="java">Scanner inputStream = new Scanner(file).useDelimiter(",");</code>
Copy after login

This will instruct Scanner to treat commas as field separators, thereby preserving the integrity of fields with spaces.

Example:

Using this corrected code, the CSV data provided in the question will be parsed as follows:

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
Copy after login

Each field, including those with spaces, will be captured as a single unit, resulting in the desired output.

The above is the detailed content of How to Handle Spaces Correctly When Reading CSV Files with Scanner() in Java?. For more information, please follow other related articles on the PHP Chinese website!

source:php
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template