- Type Parameters:
T- the type of the CSV record.
- All Implemented Interfaces:
Closeable,AutoCloseable,Iterable<T>
The CSV records are read iteratively, regardless of whether the Iterable, the Iterator, or the Stream is used. Once all records are read, the data is consumed. If you need to repeatedly read records, you should collect the records in a List or another collection.
Example use:
try (CsvReader<CsvRecord> csv = CsvReader.builder().ofCsvRecord(file)) {
for (CsvRecord csvRecord : csv) {
// ...
}
}
Example for named records:
try (CsvReader<NamedCsvRecord> csv = CsvReader.builder().ofNamedCsvRecord(file)) {
for (NamedCsvRecord csvRecord : csv) {
// ...
}
}
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic final classThis builder is used to create configured instances ofCsvReader. -
Method Summary
Modifier and TypeMethodDescriptionstatic CsvReader.CsvReaderBuilderbuilder()Constructs aCsvReader.CsvReaderBuilderto configure and build instances of this class.voidclose()iterator()Returns an iterator over elements of typeCsvRecord.voidskipLines(int lineCount) Skips the specified number of lines.intSkip lines until the specified predicate matches.Returns aSpliteratorover elements of typeCsvRecord.stream()Returns a new sequentialStreamwith this reader as its source.toString()
-
Method Details
-
builder
Constructs aCsvReader.CsvReaderBuilderto configure and build instances of this class.- Returns:
- a new
CsvReader.CsvReaderBuilderinstance.
-
skipLines
public void skipLines(int lineCount) Skips the specified number of lines.The setting
CsvReader.CsvReaderBuilder.skipEmptyLines(boolean)has no effect on this method.- Parameters:
lineCount- the number of lines to skip.- Throws:
IllegalArgumentException- if lineCount is negative.UncheckedIOException- if an I/O error occurs.CsvParseException- if not enough lines are available to skip.
-
skipLines
Skip lines until the specified predicate matches. The line that matches the predicate is not skipped.The method returns the number of lines actually skipped.
The setting
CsvReader.CsvReaderBuilder.skipEmptyLines(boolean)has no effect on this method.- Parameters:
predicate- the predicate to match the lines.maxLines- the maximum number of lines to skip.- Returns:
- the number of lines actually skipped.
- Throws:
NullPointerException- if predicate isnull.UncheckedIOException- if an I/O error occurs.CsvParseException- if no matching line is found within the maximum limit of maxLines.
-
iterator
Returns an iterator over elements of typeCsvRecord.The returned iterator is not thread-safe. Remember to close the returned iterator when you're done. Alternatively, use
stream().
This method is idempotent and can be called multiple times.- Specified by:
iteratorin interfaceIterable<T>- Returns:
- an iterator over the CSV records.
- Throws:
UncheckedIOException- if an I/O error occurs.CsvParseException- if any other problem occurs when parsing the CSV data.- See Also:
-
spliterator
Returns aSpliteratorover elements of typeCsvRecord.The returned spliterator is not thread-safe. Remember to invoke
close()when you're done. Alternatively, usestream().
This method is idempotent and can be called multiple times.- Specified by:
spliteratorin interfaceIterable<T>- Returns:
- a spliterator over the CSV records.
- Throws:
UncheckedIOException- if an I/O error occurs.CsvParseException- if any other problem occurs when parsing the CSV data.- See Also:
-
stream
Returns a new sequentialStreamwith this reader as its source.The returned stream is not thread-safe. Remember to close the returned stream when you're done. Closing the stream will also close this reader.
This method can be called multiple times, although it creates a new stream each time.
The stream is not reusable after it has been closed.- Returns:
- a sequential
Streamover the CSV records. - Throws:
UncheckedIOException- if an I/O error occurs.CsvParseException- if any other problem occurs when parsing the CSV data.- See Also:
-
close
- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable- Throws:
IOException
-
toString
-