ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

java-jackson-dataformat-csv:没有POJO的映射数字值

2019-12-11 02:02:54  阅读:201  来源: 互联网

标签:csv jackson jackson-dataformat-csv java


我正在尝试使用jackson-dataformat-csv解析CSV文件,我想将数字列映射到Number java类型.

CsvSchema schema = CsvSchema.builder().setUseHeader(true)
    .addColumn("firstName", CsvSchema.ColumnType.STRING)
    .addColumn("lastName", CsvSchema.ColumnType.STRING)
    .addColumn("age", CsvSchema.ColumnType.NUMBER)
    .build();

CsvMapper csvMapper = new CsvMapper();  

MappingIterator<Map<String, Object>> mappingIterator = csvMapper
        .readerFor(Map.class)
        .with(schema)
        .readValues(is);        

while (mappingIterator.hasNext()) {
    Map<String, Object> entryMap = mappingIterator.next();
    Number age = (Number) entryMap.get("age");
}       

我期望entryMap.get(“ age”)应该是一个数字,但是我却得到了String.

我的CSV文件:

firstName,lastName,age
John,Doe,21
Error,Name,-10

我知道CsvSchema可以很好地与POJO配合使用,但是我需要处理任意的CSV模式,因此我不能为每种情况创建一个新的Java类.

有什么方法可以将CSV解析为类型化的Map或Array?

解决方法:

您可以将univocity-parsers用于此类事情.它更快,更灵活:

var settings = new CsvParserSettings(); //configure the parser if needed
var parser = new CsvParser(settings);

for (Record record : parser.iterateRecords(is)) {
    Short age = record.getShort("age");
}

要获取类型化的映射,请告诉解析器您正在使用的列的类型是什么:

parser.getRecordMetadata().setTypeOfColumns(Short.class, "age" /*, and other column names*/);

//to get 0 instead of nulls when the field is empty in the file:
parser.getRecordMetadata().setDefaultValueOfColumns("0", "age", /*, and other column names*/);

// then parse
for (Record record : parser.iterateRecords(is)) {
    Map<String,Object> map = record.toFieldMap();
}

希望这可以帮助

免责声明:我是这个图书馆的作者.它是开源且免费的(Apache 2.0许可证)

标签:csv,jackson,jackson-dataformat-csv,java
来源: https://codeday.me/bug/20191211/2105803.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有