Class CSVPrinter
- All Implemented Interfaces:
- Closeable,- Flushable,- AutoCloseable
CSV format.
 Values can be appended to the output by calling the print(Object) method.
 Values are printed according to String.valueOf(Object).
 To complete a record the println() method has to be called.
 Comments can be appended by calling printComment(String).
 However a comment will only be written to the output if the CSVFormat supports comments.
 
The printer also supports appending a complete record at once by calling printRecord(Object...)
 or printRecord(Iterable).
 Furthermore printRecords(Object...), printRecords(Iterable) and printRecords(ResultSet)
 methods can be used to print several records at once.
 
Example:
 try (CSVPrinter printer = new CSVPrinter(new FileWriter("csv.txt"), CSVFormat.EXCEL)) {
     printer.printRecord("id", "userName", "firstName", "lastName", "birthday");
     printer.printRecord(1, "john73", "John", "Doe", LocalDate.of(1973, 9, 15));
     printer.println();
     printer.printRecord(2, "mary", "Mary", "Meyer", LocalDate.of(1985, 3, 29));
 } catch (IOException ex) {
     ex.printStackTrace();
 }
 
 This code will write the following to csv.txt:
id,userName,firstName,lastName,birthday 1,john73,John,Doe,1973-09-15 2,mary,Mary,Meyer,1985-03-29
- 
Constructor SummaryConstructorsConstructorDescriptionCSVPrinter(Appendable appendable, CSVFormat format) Creates a printer that will print values to the given stream following the CSVFormat.
- 
Method SummaryModifier and TypeMethodDescriptionvoidclose()voidclose(boolean flush) Closes the underlying stream with an optional flush first.voidflush()Flushes the underlying stream.getOut()Gets the target Appendable.longGets the record count printed, this does not include comments or headers.voidPrints the string as the next value on the line.voidprintComment(String comment) Prints a comment on a new line among the delimiter-separated values.voidprintHeaders(ResultSet resultSet) Prints headers for a result set based on its metadata.voidprintln()Prints the record separator.voidprintRecord(Iterable<?> values) Prints the given values as a single record of delimiter-separated values followed by the record separator.voidprintRecord(Object... values) Prints the given values as a single record of delimiter-separated values followed by the record separator.voidprintRecord(Stream<?> values) Prints the given values as a single record of delimiter-separated values followed by the record separator.voidprintRecords(Iterable<?> values) Prints all the objects in the givenIterablehandling nested collections/arrays as records.voidprintRecords(Object... values) Prints all the objects in the given array handling nested collections/arrays as records.voidprintRecords(ResultSet resultSet) Prints all the objects in the given JDBC result set.voidprintRecords(ResultSet resultSet, boolean printHeader) Prints all the objects with metadata in the given JDBC result set based on the header boolean.voidprintRecords(Stream<?> values) Prints all the objects in the givenStreamhandling nested collections/arrays as records.
- 
Constructor Details- 
CSVPrinterCreates a printer that will print values to the given stream following the CSVFormat.Currently, only a pure encapsulation format or a pure escaping format is supported. Hybrid formats (encapsulation and escaping with a different character) are not supported. - Parameters:
- appendable- stream to which to print. Must not be null.
- format- the CSV format. Must not be null.
- Throws:
- IOException- thrown if the optional header cannot be printed.
- IllegalArgumentException- thrown if the parameters of the format are inconsistent.
- NullPointerException- thrown if either parameters are null.
 
 
- 
- 
Method Details- 
close- Specified by:
- closein interface- AutoCloseable
- Specified by:
- closein interface- Closeable
- Throws:
- IOException
 
- 
closeCloses the underlying stream with an optional flush first.- Parameters:
- flush- whether to flush before the actual close.
- Throws:
- IOException- If an I/O error occurs
- Since:
- 1.6
- See Also:
 
- 
flushFlushes the underlying stream.- Specified by:
- flushin interface- Flushable
- Throws:
- IOException- If an I/O error occurs
 
- 
getOutGets the target Appendable.- Returns:
- the target Appendable.
 
- 
getRecordCountGets the record count printed, this does not include comments or headers.- Returns:
- the record count, this does not include comments or headers.
- Since:
- 1.13.0
 
- 
printPrints the string as the next value on the line. The value will be escaped or encapsulated as needed.- Parameters:
- value- value to be output.
- Throws:
- IOException- If an I/O error occurs
 
- 
printCommentPrints a comment on a new line among the delimiter-separated values.Comments will always begin on a new line and occupy at least one full line. The character specified to start comments and a space will be inserted at the beginning of each new line in the comment. If comments are disabled in the current CSV format this method does nothing. This method detects line breaks inside the comment string and inserts CSVFormat.getRecordSeparator()to start a new line of the comment. Note that this might produce unexpected results for formats that do not use line breaks as record separators.- Parameters:
- comment- the comment to output
- Throws:
- IOException- If an I/O error occurs
 
- 
printHeadersPrints headers for a result set based on its metadata.- Parameters:
- resultSet- The ResultSet to query for metadata.
- Throws:
- IOException- If an I/O error occurs.
- SQLException- If a database access error occurs or this method is called on a closed result set.
- Since:
- 1.9.0
 
- 
printlnPrints the record separator.- Throws:
- IOException- If an I/O error occurs
 
- 
printRecordPrints the given values as a single record of delimiter-separated values followed by the record separator.The values will be quoted if needed. Quotes and newLine characters will be escaped. This method adds the record separator to the output after printing the record, so there is no need to call println().- Parameters:
- values- values to output.
- Throws:
- IOException- If an I/O error occurs
 
- 
printRecordPrints the given values as a single record of delimiter-separated values followed by the record separator.The values will be quoted if needed. Quotes and newLine characters will be escaped. This method adds the record separator to the output after printing the record, so there is no need to call println().- Parameters:
- values- values to output.
- Throws:
- IOException- If an I/O error occurs
 
- 
printRecordPrints the given values as a single record of delimiter-separated values followed by the record separator.The values will be quoted if needed. Quotes and newLine characters will be escaped. This method adds the record separator to the output after printing the record, so there is no need to call println().- Parameters:
- values- values to output.
- Throws:
- IOException- If an I/O error occurs
- Since:
- 1.10.0
 
- 
printRecordsPrints all the objects in the givenIterablehandling nested collections/arrays as records.If the given Iterable only contains simple objects, this method will print a single record like printRecord(Iterable). If the given Iterable contains nested collections/arrays those nested elements will each be printed as records usingprintRecord(Object...).Given the following data structure: List<String[]> data = new ArrayList<>(); data.add(new String[]{ "A", "B", "C" }); data.add(new String[]{ "1", "2", "3" }); data.add(new String[]{ "A1", "B2", "C3" });Calling this method will print: A, B, C 1, 2, 3 A1, B2, C3- Parameters:
- values- the values to print.
- Throws:
- IOException- If an I/O error occurs
 
- 
printRecordsPrints all the objects in the given array handling nested collections/arrays as records.If the given array only contains simple objects, this method will print a single record like printRecord(Object...). If the given collections contain nested collections or arrays, those nested elements will each be printed as records usingprintRecord(Object...).Given the following data structure: String[][] data = new String[3][] data[0] = String[]{ "A", "B", "C" }; data[1] = new String[]{ "1", "2", "3" }; data[2] = new String[]{ "A1", "B2", "C3" };Calling this method will print: A, B, C 1, 2, 3 A1, B2, C3- Parameters:
- values- the values to print.
- Throws:
- IOException- If an I/O error occurs
 
- 
printRecordsPrints all the objects in the given JDBC result set.You can use CSVFormat.Builder.setMaxRows(long)to limit how many rows a result set produces. This is most useful when you cannot limit rows throughStatement.setLargeMaxRows(long)orStatement.setMaxRows(int).- Parameters:
- resultSet- The values to print.
- Throws:
- IOException- If an I/O error occurs.
- SQLException- Thrown when a database access error occurs.
 
- 
printRecordsPrints all the objects with metadata in the given JDBC result set based on the header boolean.You can use CSVFormat.Builder.setMaxRows(long)to limit how many rows a result set produces. This is most useful when you cannot limit rows throughStatement.setLargeMaxRows(long)orStatement.setMaxRows(int).- Parameters:
- resultSet- source of row data.
- printHeader- whether to print headers.
- Throws:
- IOException- If an I/O error occurs
- SQLException- if a database access error occurs
- Since:
- 1.9.0
 
- 
printRecordsPrints all the objects in the givenStreamhandling nested collections/arrays as records.If the given Stream only contains simple objects, this method will print a single record like printRecord(Iterable). If the given Stream contains nested collections/arrays those nested elements will each be printed as records usingprintRecord(Object...).Given the following data structure: List<String[]> data = new ArrayList<>(); data.add(new String[]{ "A", "B", "C" }); data.add(new String[]{ "1", "2", "3" }); data.add(new String[]{ "A1", "B2", "C3" }); Stream<String[]> stream = data.stream();Calling this method will print: A, B, C 1, 2, 3 A1, B2, C3- Parameters:
- values- the values to print.
- Throws:
- IOException- If an I/O error occurs
- Since:
- 1.10.0
 
 
-