Java写CSV文件的正确姿势

简介: Java写CSV文件的正确姿势

一、简介

本文讲述如何用java来写csv文件。 CSV的意思是逗号分隔符(Comma-Separated-Values),是不同系统之间传输数据的一种常见方式。

要想写csv文件需要用到java.io 包。本文将讲述如何处理特殊字符。我们的目标是写出Microsoft Excel和google sheets可以读取的csv文件。

给出java例子后,我们还将给出一些好用的第三方库

二、利用PrintWriter

2.1. 写 CSV

我们写一个方法,讲传入的字符串数组转成逗号分隔符的字符串:

1. public String convertToCSV(String[] data) {
2. return Stream.of(data)
3.       .map(this::escapeSpecialCharacters)
4.       .collect(Collectors.joining(","));
5. }

调用这个方法之前,我们先造下数据

1. List<String[]> dataLines = new ArrayList<>();
2. dataLines.add(new String[] 
3.   { "John", "Doe", "38", "Comment Data\nAnother line of comment data" });
4. dataLines.add(new String[] 
5.   { "Jane", "Doe, Jr.", "19", "She said \"I'm being quoted\"" });

调用方法写出到文件

1. public void givenDataArray_whenConvertToCSV_thenOutputCreated() throws IOException {
2. File csvOutputFile = new File(CSV_FILE_NAME);
3. try (PrintWriter pw = new PrintWriter(csvOutputFile)) {
4.         dataLines.stream()
5.           .map(this::convertToCSV)
6.           .forEach(pw::println);
7.     }
8.     assertTrue(csvOutputFile.exists());
9. }

2.2. 处理特殊字符

我们重点处理逗号,引号和换行符。包含逗号和引号的字符将包上双引号,而双引号也会被用双引号转义。我们用空格来替换换行符。

1. public String escapeSpecialCharacters(String data) {
2. String escapedData = data.replaceAll("\\R", " ");
3. if (data.contains(",") || data.contains("\"") || data.contains("'")) {
4.         data = data.replace("\"", "\"\"");
5.         escapedData = "\"" + data + "\"";
6.     }
7. return escapedData;
8. }

 

3. 第三方库

从上面的例子可以看出,写CSV文件最头痛的就是处理特殊字符。下面有几个非常不错的第三方库:

4. 结论

本文演示如何用PrintWriter写CSV文件。然后讨论了如何处理特殊字符。给出示例代码之后介绍了常用的第三方类库。

 

英文原文:https://www.baeldung.com/java-csv

源码:https://github.com/eugenp/tutorials/tree/master/core-java-io

如果觉得本文对你有帮助,欢迎点赞评论,欢迎关注我,我将努力创作更多更好的文章。

相关文章
|
19天前
|
Java
Java“解析时到达文件末尾”解决
在Java编程中,“解析时到达文件末尾”通常指在读取或处理文件时提前遇到了文件结尾,导致程序无法继续读取所需数据。解决方法包括:确保文件路径正确,检查文件是否完整,使用正确的文件读取模式(如文本或二进制),以及确保读取位置正确。合理设置缓冲区大小和循环条件也能避免此类问题。
|
24天前
|
Java
利用GraalVM将java文件变成exe可执行文件
这篇文章简明地介绍了如何使用GraalVM将一个简单的Java程序编译成exe可执行文件,首先通过javac命令编译Java文件生成class文件,然后使用native-image命令将class文件转换成独立的exe文件,并展示了如何运行这个exe文件。
36 0
利用GraalVM将java文件变成exe可执行文件
|
2月前
|
Java Linux
java基础(3)安装好JDK后使用javac.exe编译java文件、java.exe运行编译好的类
本文介绍了如何在安装JDK后使用`javac.exe`编译Java文件,以及使用`java.exe`运行编译好的类文件。涵盖了JDK的安装、环境变量配置、编写Java程序、使用命令行编译和运行程序的步骤,并提供了解决中文乱码的方法。
48 1
|
1天前
|
Java 数据格式 索引
使用 Java 字节码工具检查类文件完整性的原理是什么
Java字节码工具通过解析和分析类文件的字节码,检查其结构和内容是否符合Java虚拟机规范,确保类文件的完整性和合法性,防止恶意代码或损坏的类文件影响程序运行。
|
1天前
|
Java API Maven
如何使用 Java 字节码工具检查类文件的完整性
本文介绍如何利用Java字节码工具来检测类文件的完整性和有效性,确保类文件未被篡改或损坏,适用于开发和维护阶段的代码质量控制。
|
24天前
|
Java
用java搞定时任务,将hashmap里面的值存到文件里面去
本文介绍了如何使用Java的`Timer`和`TimerTask`类创建一个定时任务,将HashMap中的键值对写入到文本文件中,并提供了完整的示例代码。
30 1
用java搞定时任务,将hashmap里面的值存到文件里面去
|
11天前
|
Java
Java开发如何实现文件的移动,但是在移动结束后才进行读取?
【10月更文挑战第13天】Java开发如何实现文件的移动,但是在移动结束后才进行读取?
34 2
|
11天前
|
Java Apache Maven
Java将word文档转换成pdf文件的方法?
【10月更文挑战第13天】Java将word文档转换成pdf文件的方法?
26 1
|
11天前
|
监控 Java
Java定时扫码一个文件夹下的文件,如何保证文件写入完成后才进行处理?
【10月更文挑战第13天】Java定时扫码一个文件夹下的文件,如何保证文件写入完成后才进行处理?
42 1
|
1月前
|
Java
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
50 2
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下