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

前端之家收集整理的这篇文章主要介绍了java-jackson-dataformat-csv:没有POJO的映射数字值 前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

  1. CsvSchema schema = CsvSchema.builder().setUseHeader(true)
  2. .addColumn("firstName",CsvSchema.ColumnType.STRING)
  3. .addColumn("lastName",CsvSchema.ColumnType.STRING)
  4. .addColumn("age",CsvSchema.ColumnType.NUMBER)
  5. .build();
  6. CsvMapper csvMapper = new CsvMapper();
  7. MappingIterator<Map<String,Object>> mappingIterator = csvMapper
  8. .readerFor(Map.class)
  9. .with(schema)
  10. .readValues(is);
  11. while (mappingIterator.hasNext()) {
  12. Map<String,Object> entryMap = mappingIterator.next();
  13. Number age = (Number) entryMap.get("age");
  14. }

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

我的CSV文件

  1. firstName,lastName,age
  2. John,Doe,21
  3. Error,Name,-10

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

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

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

  1. var settings = new CsvParserSettings(); //configure the parser if needed
  2. var parser = new CsvParser(settings);
  3. for (Record record : parser.iterateRecords(is)) {
  4. Short age = record.getShort("age");
  5. }

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

  1. parser.getRecordMetadata().setTypeOfColumns(Short.class,"age" /*,and other column names*/);
  2. //to get 0 instead of nulls when the field is empty in the file:
  3. parser.getRecordMetadata().setDefaultValueOfColumns("0","age",/*,and other column names*/);
  4. // then parse
  5. for (Record record : parser.iterateRecords(is)) {
  6. Map<String,Object> map = record.toFieldMap();
  7. }

希望这可以帮助

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

猜你在找的Java相关文章