Jackson CsvMapper 将对象与地图映射到 csv

发布于 2025-01-13 07:41:39 字数 930 浏览 2 评论 0原文

我有一个复杂的 java 对象,我想使用 Jacksons CsvMapper 将其映射到 csv。

public class TestObject {
  private Map<String, Map<String, String>> values;
  @JsonAnyGetter
  public Map<String, Map<String, String>> getValues() {
      return values;
  }

  @JsonAnySetter
  public void setValues(Map<String, Map<String, String>> values) {
    this.values = values;
  }

}

该对象是 TestObjects 列表:

 CsvMapper mapper = new CsvMapper(); 
 CsvSchema schema = mapper.schemaFor(clazz).withUseHeader(true);
 
 ObjectWriter myObjectWriter = mapper.writer(schema);
 return myObjectWriter.writeValueAsString(objectList);

但是,当我尝试将其映射到 csv 时,由于地图中的值(因为它是地图的地图),我收到错误。

Caused by: com.fasterxml.jackson.dataformat.csv.CsvMappingException: Unrecognized column 'test_column': known columns: ....

有谁知道如何让 jacksons csvmapper 正确地将这张地图转换为 csv?

I have a complex java object that I want to map to csv using Jacksons CsvMapper.

public class TestObject {
  private Map<String, Map<String, String>> values;
  @JsonAnyGetter
  public Map<String, Map<String, String>> getValues() {
      return values;
  }

  @JsonAnySetter
  public void setValues(Map<String, Map<String, String>> values) {
    this.values = values;
  }

}

The object is a list of TestObjects:

 CsvMapper mapper = new CsvMapper(); 
 CsvSchema schema = mapper.schemaFor(clazz).withUseHeader(true);
 
 ObjectWriter myObjectWriter = mapper.writer(schema);
 return myObjectWriter.writeValueAsString(objectList);

However when I try to map this to csv, I get an error due to the values in the map since its a map of map.

Caused by: com.fasterxml.jackson.dataformat.csv.CsvMappingException: Unrecognized column 'test_column': known columns: ....

Does anyone know how I can get jacksons csvmapper to correctly convert this map of maps to csv?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

会发光的星星闪亮亮i 2025-01-20 07:41:39

这可能会解决你的问题。完整示例此处

/**
 * @param listOfMap
 * @param writer
 * @throws IOException
 */
public static void csvWriter(List<HashMap<String, String>> listOfMap, Writer writer) throws IOException {
    CsvSchema schema = null;
    CsvSchema.Builder schemaBuilder = CsvSchema.builder();
    if (listOfMap != null && !listOfMap.isEmpty()) {
        for (String col : listOfMap.get(0).keySet()) {
            schemaBuilder.addColumn(col);
        }
        schema = schemaBuilder.build().withLineSeparator(System.lineSeparator()).withHeader();
    }
    CsvMapper mapper = new CsvMapper();
    mapper.writer(schema).writeValues(writer).writeAll(listOfMap);
    writer.flush();
}

This might solve your problem. Full example here

/**
 * @param listOfMap
 * @param writer
 * @throws IOException
 */
public static void csvWriter(List<HashMap<String, String>> listOfMap, Writer writer) throws IOException {
    CsvSchema schema = null;
    CsvSchema.Builder schemaBuilder = CsvSchema.builder();
    if (listOfMap != null && !listOfMap.isEmpty()) {
        for (String col : listOfMap.get(0).keySet()) {
            schemaBuilder.addColumn(col);
        }
        schema = schemaBuilder.build().withLineSeparator(System.lineSeparator()).withHeader();
    }
    CsvMapper mapper = new CsvMapper();
    mapper.writer(schema).writeValues(writer).writeAll(listOfMap);
    writer.flush();
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文