利用jackson-dataformat-csv读写csv文件

article/2025/1/17 3:16:14

利用jackson-dataformat-csv读写csv文件


csv是comma-separated values的缩写,这类文件在日常项目中有时比较常见。sql工具一般具有将数据库数据导入、导出csv格式。

利用jackson-dataformat-csv读写csv文件,重点在与两个类:CsvMapper和CsvSchema。其中CsvMapper和我们利用jackson转换son数据用的那个类相似,承担java对象和csv格式字符串之间的转换。CsvSchema则定义了读写csv数据的那些属性名。

        CsvMapper csvMapper = new CsvMapper();CsvSchema csvSchema = csvMapper.schemaFor(CostDetail.class);

    上面两行代码代表这两个类之间的关系。上面设置并不会把csv值的属性名写到文件头即文件的第一行。如果要写入,则:

        CsvSchema csvSchema = csvMapper.schemaFor(CostDetail.class).withHeader();

    读取csv文件也同样,一般csv文件第一行代表各列数据在java对象中的属性名。


CostDetail costDetail = new CostDetail();costDetail.setAmount(BigDecimal.valueOf(12.55D));costDetail.setApplyId(11L);costDetail.setCostCenterId(66L);costDetail.setCreatedTime(new Date());costDetail.setStatus(1L);costDetail.setTypeId(77L);costDetail.setTypeName("v");costDetail.setUserId(88L);CsvMapper csvMapper = new CsvMapper();CsvSchema csvSchema = csvMapper.schemaFor(CostDetail.class).withHeader();System.out.println(csvSchema);csvSchema.forEach(t -> System.out.println(t.getName()));try (SequenceWriter writer = csvMapper.writer(csvSchema).writeValues(new File("csv.csv"));) {writer.write(costDetail);// ---} catch (Exception e) {throw e;}

上面代码写入的数据文件内容:

amount,applyId,costCenterId,createdTime,status,typeId,typeName,userId
12.55,11,66,1456649517855,1,77,v,88



那我们看下如何读取数据的:

文件内容为:

amount,applyId,costCenterId,createdTime,status,typeId,typeName,userId
12.55,11,66,1456646940091,1,77,v,88
112.55,111,616,1456646940091,1,77,v,84


 CsvSchema schema = CsvSchema.emptySchema().withHeader();System.out.println("read from file");try (InputStream inputStream = JacksonDataformatCsvFile.class.getClassLoader().getResourceAsStream("data.csv");) {MappingIterator<CostDetail> values = csvMapper.readerFor(CostDetail.class).with(schema).readValues(inputStream);values.forEachRemaining(System.out::println);} catch (Exception e) {// TODO: handle exception}

输出:


 CsvSchema schema = CsvSchema.emptySchema().withHeader();


这行代表值的属性名获取来自文件的第一行。

你是否注意到日期到格式化是不是太。。。

我们可以配置:

        csvMapper.setDateFormat(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"));

来格式化日期。

amount,applyId,costCenterId,createdTime,status,typeId,typeName,userId
12.55,11,66,"2016-02-28 17:08:36",1,77,v,88



http://chatgpt.dhexx.cn/article/ip0qRd1H.shtml

相关文章

FormData详解

FormData 接口提供了一种表示表单数据的键值对 key/value 的构造方式&#xff0c;并且可以轻松的将数据通过XMLHttpRequest.send() 方法发送出去&#xff0c;本接口和此方法都相当简单直接。如果表单 enctype 属性设为 multipart/form-data &#xff0c;则会使用表单的 submit(…

源码解析-为什么引入了jackson-dataformat-xml 包我的接口全变成了xml格式?

本文从引入jackson-dataformat-xml 之后接口全变成xml 现象开始&#xff0c;一步步排查代码原因&#xff0c;并提出解决方案。希望能对遇到相关问题的人有所帮助 新调用上游一个接口&#xff0c;增加了对方的一个api包&#xff0c;没修改任何逻辑&#xff0c;接口却从json返回…

Java-常用API(StringBuffer,Math,Date,DataFormat,Calender,Runtime,System,包装类)

Java常用API StringBuffer 为了解决String字符串操作导致的内存冗余&#xff0c;提高效率&#xff0c;Java中提供了StringBuffer和StringBuilder来操作字符串&#xff0c;并且提供了很多方法&#xff0c;便于程序员开发 StringBuffer和StringBuilder中都有char类型可变长数组…

Java知识点--DataFormat,SimpleDateFormat和DateTimeFormatter

Java知识点–DataFormat&#xff0c;SimpleDateFormat和DateTimeFormatter 这个知识点没什么难懂的地方&#xff0c;就不一一赘述了。 import java.text.DateFormat; import java.util.Date; import java.util.Locale;public class test01 {public static void main(String[]…

04、添加 com.fasterxml.jackson.dataformat -- jackson-dataformat-xml 依赖报错

Correct the classpath of your application so that it contains a single, compatible version of com.fasterxml.jackson.dataformat.xml.XmlMapper 解决&#xff1a; 改用其他版本&#xff0c;我没写版本号&#xff0c;springboot自己默认的是 2.11.4 版本 成功启动项目…

Excel表格样式CellStyle的DataFormat可选值

Excel表格样式CellStyle的DataFormat可选值 干啥子遇到的问题DataFormat可选项源码查看出处1、访问https://poi.apache.org/apidocs/4.1/ ,全局搜索CellStyle2、找到其对应的类-BuiltinFormats 干啥子 解决表格样式的设置&#xff0c;找到DataFormat可选值。 遇到的问题 在使…

java中的Date类,DataFormat类及Calendar类的使用详解

Date类的构造方法 Date类拥有多个构造函数&#xff0c;只是部分已经过时&#xff0c;但是其中有未过时的构造函数可以把毫秒值转成日期对象。 /* * Date类的long参数的构造方法 * Date(long ) 表示毫秒值 * 传递毫秒值,将毫秒值转成对应的日期对象 * 结果为…

Java 常用类Data和Format类 使用教程

一、Date类使用方法。 1. new Date() 返回当前时间 Date date new Date(); System.out.println(date);//输出当前的时间。源码解释为&#xff1a; 2. new Date(10006060*24); 返回 从 Fri Jan 01 08:00:00 CST 1970经过1天的时间 long time 1000*60*60*24; Date date n…

矩阵按键行列反转扫描法

51单片机 | 矩阵键盘行扫描 ———————————————————————————————————————————— 分类&#xff1a; 按结构原理分&#xff1a; 触点式开关按键无触点开关按键 接入方式 独立式按键矩阵式键盘 ———————————————————…

基于GD32矩阵按键程序实现

目录 一、简介 二、原理图 三、程序实现 一、简介 矩阵键盘&#xff0c;也称矩阵按键&#xff0c;是为了节约单片机IO口占用所引入的一种外设。 二、矩阵按键的原理图 三、程序实现 GPIO初始化引脚代码 /*!\brief Init Key Function\param[in] none\param[out] non…

4、按键(独立/矩阵按键)

一、 独立按键原理 按键在闭合和断开时&#xff0c;触点会存在抖动现象。 PS:定义小灯时&#xff0c;如果定义为#define led P2&#xff0c;这样按下K1时八个灯就会同时熄灭或点亮&#xff0c;&#xff0c;当然&#xff0c;如果要其中几个灯点亮&#xff0c;就分别定义…

蓝桥杯单片机 独立按键与矩阵按键

文章目录 前言一、蓝桥杯按键原理图二、独立按键与矩阵按键处理思路 1.独立按键2.矩阵按键代码实现总结 前言 按键设计一般分为两种&#xff1a;独立按键和矩阵键盘。按键数量较少的用前者&#xff0c;按键数量较多的用后者。虽然两种设计都是操作按键&#xff0c;但是其键盘扫…

单片机STM32入门——(3)矩阵按键

单片机STM32入门——&#xff08;3&#xff09;矩阵按键 1.理论分析1.1键盘扫描方式1.2行扫描逻辑1.3列扫描逻辑 2.程序编写2.1按键扫描程序2.1.1按键初始化2.1.2按键扫描程序头文件2.1.3行扫描函数2.1.3列扫描函数 2.2主程序 1.理论分析 1.1键盘扫描方式 我们所用到的键盘为…

51单片机之按键(独立按键矩阵按键)

难的东西学不会是因为简单的知识没学好 基础不牢&#xff0c;地动山摇 按键 1.1基础温习 &#xff08;1&#xff09;按键的物理结构 &#xff08;2&#xff09;单片机引脚有两种状态&#xff08;I/O&#xff09;输入【读】或者输出【写】 &#xff08;3&#xff09;上拉电阻…

51学习-矩阵按键篇

使用并行接口方式连接键盘&#xff0c;对独立式键盘而言&#xff0c;8根I/O口线可以接 **8** 个按键&#xff0c;而对矩阵式键盘而言&#xff0c;8根I/O口线最多可以接 **64** 个按键。 项目(工程)的时候&#xff0c;我们经常要用到比较多的按键&#xff0c;而且IO资源紧张&am…

4x4矩阵按键应用详解

一.简介 4x4矩阵按键是单片机外部设备中所使用的排布类似于矩阵的按键组。显然矩阵按键的使用要比独立按键要复杂一些&#xff0c;编程也要复杂一些&#xff0c;但可以单片机IO资源。4x4矩阵按键即分为4组列线&#xff0c;4组行线&#xff0c;并将行线所接的单片机的I/O口作为…

独立按键和矩阵按键c语言,第八章 独立按键和矩阵按键

我们和单片机之间进行信息交互,主要包含两大类,输入设备和输出设备。前边讲的LED小灯、数码管、点阵都是输出设备,这节课我们学习一下最常用的输入设备——按键。在本节课的学习过程中我们还会穿插介绍一点硬件设计的基础知识。 8.1单片机最小系统电路解析 8.1.1电源 我们在…

单片机 矩阵式按键

单片机 矩阵式按键 一、简述 在单片机应用系统中&#xff0c;通过按键实现数据输入及功能控制是非常普遍的&#xff0c;通常在所需按键数量不多时&#xff0c;系统常采用独立式按键。需要按键数量比较多&#xff0c;为了减少I/O口的占用&#xff0c;通常将按键排列成矩阵。测…

矩阵按键原理和BUG

当我们的电路有很多按键时&#xff0c;一般会采用矩阵方式与单片机相连来减少对单片机IO的浪费&#xff0c;如下图方式。 这个电路的原理: 1、比如检测S13是否按下&#xff0c;单片机把Line4设为输出&#xff0c;并输出低电平&#xff0c;而Line3、Line2、Line1设为开路输入&…

关于矩阵按键

前段时间老师讲了矩阵按键&#xff0c;就把程序的理解写下来 看图片&#xff0c;只有主函数和串口。串口在此用来发送我们的按键值&#xff0c;波特率9600&#xff0c;频率11.0592。 我们用的是4*4矩阵按键 我们的矩阵按键连在了单片机的P0口&#xff08;stc15f2k60s2&#xf…