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

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

相关文章
|
6天前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
20 2
|
1月前
|
Java
Java“解析时到达文件末尾”解决
在Java编程中,“解析时到达文件末尾”通常指在读取或处理文件时提前遇到了文件结尾,导致程序无法继续读取所需数据。解决方法包括:确保文件路径正确,检查文件是否完整,使用正确的文件读取模式(如文本或二进制),以及确保读取位置正确。合理设置缓冲区大小和循环条件也能避免此类问题。
|
1月前
|
Java
利用GraalVM将java文件变成exe可执行文件
这篇文章简明地介绍了如何使用GraalVM将一个简单的Java程序编译成exe可执行文件,首先通过javac命令编译Java文件生成class文件,然后使用native-image命令将class文件转换成独立的exe文件,并展示了如何运行这个exe文件。
63 0
利用GraalVM将java文件变成exe可执行文件
|
9天前
|
存储 缓存 安全
在 Java 编程中,创建临时文件用于存储临时数据或进行临时操作非常常见
在 Java 编程中,创建临时文件用于存储临时数据或进行临时操作非常常见。本文介绍了使用 `File.createTempFile` 方法和自定义创建临时文件的两种方式,详细探讨了它们的使用场景和注意事项,包括数据缓存、文件上传下载和日志记录等。强调了清理临时文件、确保文件名唯一性和合理设置文件权限的重要性。
24 2
|
18天前
|
存储 安全 Java
如何保证 Java 类文件的安全性?
Java类文件的安全性可以通过多种方式保障,如使用数字签名验证类文件的完整性和来源,利用安全管理器和安全策略限制类文件的权限,以及通过加密技术保护类文件在传输过程中的安全。
|
20天前
|
存储 Java API
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
25 4
|
22天前
|
Java 数据格式 索引
使用 Java 字节码工具检查类文件完整性的原理是什么
Java字节码工具通过解析和分析类文件的字节码,检查其结构和内容是否符合Java虚拟机规范,确保类文件的完整性和合法性,防止恶意代码或损坏的类文件影响程序运行。
|
22天前
|
Java API Maven
如何使用 Java 字节码工具检查类文件的完整性
本文介绍如何利用Java字节码工具来检测类文件的完整性和有效性,确保类文件未被篡改或损坏,适用于开发和维护阶段的代码质量控制。
|
1月前
|
Java
用java搞定时任务,将hashmap里面的值存到文件里面去
本文介绍了如何使用Java的`Timer`和`TimerTask`类创建一个定时任务,将HashMap中的键值对写入到文本文件中,并提供了完整的示例代码。
37 1
用java搞定时任务,将hashmap里面的值存到文件里面去
|
1月前
|
Java
Java开发如何实现文件的移动,但是在移动结束后才进行读取?
【10月更文挑战第13天】Java开发如何实现文件的移动,但是在移动结束后才进行读取?
54 2