本文转自测试人社区,原文链接:https://ceshiren.com/t/topic/28202
pom文件导入
<dependency>
<groupId>com.fasterxml.jackson.dataformat</groupId>
<artifactId>jackson-dataformat-csv</artifactId>
<version>${jackson.version}</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.datatype</groupId>
<artifactId>jackson-datatype-jsr310</artifactId>
<version>${jackson.version}</version>
</dependency>
带有header的csv
orderLines.csv
item,quantity,unitPrice,orderDate
“No. 9 Sprockets”,12,1.23,2019-04-17
“Widget (10mm)”,4,3.45,2022-01-16
成员变量与header名一致
- 实体类的成员变量
- csv对应的header名
@Data
public class OrderLine{
private String item;
private int quantity;
private BigDecimal unitPrice;
private LocalDate orderDate;
public OrderLine() {
}
public OrderLine(String item, int quantity,
BigDecimal unitPrice, LocalDate orderDate) {
this.item = item;
this.quantity = quantity;
this.unitPrice = unitPrice;
this.orderDate = orderDate;
}
}
对应测试方法
@Test
void csvReadWithHeader() throws IOException {
//带着header读取
CsvSchema orderLineSchema = CsvSchema.emptySchema().withHeader();
//功能上等价的便捷方法: mapper.registerModules(mapper.findModules());
//我们需要使用 findAndRegisterModules方法,以便 Jackson正确处理我们的日期
//Jackson也可以自动搜索所有模块,不需要我们手动注册
csvMapper.findAndRegisterModules();
MappingIterator<OrderLine> orderLines = csvMapper.readerFor(OrderLine.class)
.with(orderLineSchema)
.readValues(new File("src/test/resources/csv/orderLines.csv"));
System.out.println(orderLines.readAll());
}
成员变量与header名不一致
- 实体类的成员变量
- csv对应的header名
@Data
public class OrderList {
@JsonProperty("item")
private String otherItem;
@JsonProperty("quantity")
private int qua;
@JsonProperty("unitPrice")
private BigDecimal price;
@JsonProperty("orderDate")
private LocalDate date;
}
对应测试方法
@Test
void csvReadWithHeader1() throws IOException {
//带着header读取
CsvSchema orderLineSchema = CsvSchema.emptySchema().withHeader();
//功能上等价的便捷方法: mapper.registerModules(mapper.findModules());
//我们需要使用 findAndRegisterModules方法,以便 Jackson正确处理我们的日期
//Jackson也可以自动搜索所有模块,不需要我们手动注册
csvMapper.findAndRegisterModules();
MappingIterator<OrderList> orderLines = csvMapper.readerFor(OrderList.class)
.with(orderLineSchema)
.readValues(new File("src/test/resources/csv/orderLines.csv"));
System.out.println(orderLines.readAll());
}
直接声明类型解析
readerForMapOf(String.class)
@Test
void csvReadWithHeaderMap() throws IOException {
//功能上等价的便捷方法: mapper.registerModules(mapper.findModules());
//我们需要使用 findAndRegisterModules方法,以便 Jackson正确处理我们的日期
//Jackson也可以自动搜索所有模块,不需要我们手动注册
csvMapper.findAndRegisterModules();
//.setSkipFirstDataRow(true) 第一行header不解析
CsvSchema schema = CsvSchema.builder().setSkipFirstDataRow(true)
.addColumn("item")
.addColumn("quantity")
.addColumn("unitPrice")
.addColumn("orderDate")
.build();
MappingIterator<Object> objectMappingIterator = csvMapper.readerForMapOf(String.class)
// 注意:不需要包装
.with(schema)
.readValues(new File("src/test/resources/csv/orderLines.csv"));
System.out.println(objectMappingIterator.readAll());
}
没有header的csv
orderlist.csv
“No. 9 Sprockets”,12,1.23,2019-04-17
“Widget (10mm)”,4,3.45,2022-01-16
成员变量与header名一致
- 实体类的成员变量
- csv对应的header名
@Data
public class OrderLine{
private String item;
private int quantity;
private BigDecimal unitPrice;
private LocalDate orderDate;
public OrderLine() {
}
public OrderLine(String item, int quantity,
BigDecimal unitPrice, LocalDate orderDate) {
this.item = item;
this.quantity = quantity;
this.unitPrice = unitPrice;
this.orderDate = orderDate;
}
}
对应测试方法
@Test
void csvReadOutHeader() throws IOException {
//功能上等价的便捷方法: mapper.registerModules(mapper.findModules());
//我们需要使用 findAndRegisterModules方法,以便 Jackson正确处理我们的日期
//Jackson也可以自动搜索所有模块,不需要我们手动注册
csvMapper.findAndRegisterModules();
CsvSchema schema = CsvSchema.builder()
.addColumn("item")
.addColumn("quantity")
.addColumn("unitPrice")
.addColumn("orderDate")
.build();
MappingIterator<Object> objectMappingIterator = csvMapper.readerFor(OrderLine.class)
.with(schema)
.readValues(new File("src/test/resources/csv/orderlist.csv"));
System.out.println(objectMappingIterator.readAll());
}
成员变量与header名不一致
- 实体类的成员变量
- csv对应的header名
@Data
public class OrderList {
@JsonProperty("item")
private String otherItem;
@JsonProperty("quantity")
private int qua;
@JsonProperty("unitPrice")
private BigDecimal price;
@JsonProperty("orderDate")
private LocalDate date;
}
对应测试方法
@Test
void csvReadOutHeader() throws IOException {
//功能上等价的便捷方法: mapper.registerModules(mapper.findModules());
//我们需要使用 findAndRegisterModules方法,以便 Jackson正确处理我们的日期
//Jackson也可以自动搜索所有模块,不需要我们手动注册
csvMapper.findAndRegisterModules();
CsvSchema schema = CsvSchema.builder()
.addColumn("item")
.addColumn("quantity")
.addColumn("unitPrice")
.addColumn("orderDate")
.build();
MappingIterator<Object> objectMappingIterator = csvMapper.readerFor(OrderList.class)
.with(schema)
.readValues(new File("src/test/resources/csv/orderlist.csv"));
System.out.println(objectMappingIterator.readAll());
}
直接声明类型解析
readerForMapOf(String.class)
@Test
void csvReadOutHeaderMap() throws IOException {
//功能上等价的便捷方法: mapper.registerModules(mapper.findModules());
//我们需要使用 findAndRegisterModules方法,以便 Jackson正确处理我们的日期
//Jackson也可以自动搜索所有模块,不需要我们手动注册
csvMapper.findAndRegisterModules();
CsvSchema schema = CsvSchema.builder()
.addColumn("item")
.addColumn("quantity")
.addColumn("unitPrice")
.addColumn("orderDate")
.build();
MappingIterator<Object> objectMappingIterator = csvMapper.readerForMapOf(String.class)
.with(schema)
.readValues(new File("src/test/resources/csv/orderlist.csv"));
System.out.println(objectMappingIterator.readAll());
}
推荐学习
【霍格沃兹测试开发】7天软件测试快速入门带你从零基础/转行/小白/就业/测试用例设计实战
【霍格沃兹测试开发】最新版!Web 自动化测试从入门到精通/ 电子商务产品实战/Selenium (上集)
【霍格沃兹测试开发】最新版!Web 自动化测试从入门到精通/ 电子商务产品实战/Selenium (下集)
【霍格沃兹测试开发】明星讲师精心打造最新Python 教程软件测试开发从业者必学(上集)
【霍格沃兹测试开发】明星讲师精心打造最新Python 教程软件测试开发从业者必学(下集)
【霍格沃兹测试开发】精品课合集/ 自动化测试/ 性能测试/ 精准测试/ 测试左移/ 测试右移/ 人工智能测试
【霍格沃兹测试开发】腾讯/ 百度/ 阿里/ 字节测试专家技术沙龙分享合集/ 精准化测试/ 流量回放/Diff
【霍格沃兹测试开发】Pytest 用例结构/ 编写规范 / 免费分享
【霍格沃兹测试开发】JMeter 实时性能监控平台/ 数据分析展示系统Grafana/Docker 安装
【霍格沃兹测试开发】接口自动化测试的场景有哪些?为什么要做接口自动化测试?如何一键生成测试报告?
【霍格沃兹测试开发】面试技巧指导/ 测试开发能力评级/1V1 模拟面试实战/ 冲刺年薪百万!
【霍格沃兹测试开发】腾讯软件测试能力评级标准/ 要评级表格的联系我
【霍格沃兹测试开发】Pytest 与Allure2 一键生成测试报告/ 测试用例断言/ 数据驱动/ 参数化
【霍格沃兹测试开发】App 功能测试实战快速入门/adb 常用命令/adb 压力测试
【霍格沃兹测试开发】阿里/ 百度/ 腾讯/ 滴滴/ 字节/ 一线大厂面试真题讲解,卷完拿高薪Offer !
【霍格沃兹测试开发】App自动化测试零基础快速入门/Appium/自动化用例录制/参数配置
【霍格沃兹测试开发】如何用Postman 做接口测试,从入门到实战/ 接口抓包(最新最全教程)
【霍格沃兹测试开发】6 小时轻松上手功能测试/ 软件测试工作流程/ 测试用例设计/Bug 管理
【霍格沃兹测试开发】零基础小白如何使用Postman ,从零到一做接口自动化测试/ 从零基础到进阶到实战
【霍格沃兹测试开发】建议收藏全国CCF 测试开发大赛Python 接口自动化测试赛前辅导 / 项目实战
更多软件测试开发视频教程点此
软件测试职业发展
零基础入门
测试必备编程篇
自动化测试
性能测试
测试管理
工程效能篇
面试求职篇
软件测试的面试宝典,内含一线互联网大厂面试真题、面试技巧、软件测试面试简历指导,免费领取!