我正在使用杰克逊将 POJO 序列化为 CSV。我的问题是我无法弄清楚如何在序列化时省略某些字段。我不想注释 POJO,因为它会影响需要这些字段的 JSON 和 XML 序列化。例如
public class POJO {
public string field1; //required by JSON and CSV
public string field2; //only required by JSON
}
有没有办法做到这一点?
我正在使用杰克逊将 POJO 序列化为 CSV。我的问题是我无法弄清楚如何在序列化时省略某些字段。我不想注释 POJO,因为它会影响需要这些字段的 JSON 和 XML 序列化。例如
public class POJO {
public string field1; //required by JSON and CSV
public string field2; //only required by JSON
}
有没有办法做到这一点?
对我有用的是将CsvMapper
设置设置com.fasterxml.jackson.core.JsonGenerator.Feature.IGNORE_UNKNOWN
为 true
CsvMapper mapper = new CsvMapper(); //com.fasterxml.jackson.dataformat.csv.CsvMapper
MAPPER.configure(Feature.IGNORE_UNKNOWN, true);
将所需的列添加到架构中。
CsvSchema schema = CsvSchema.builder();
.addColumn("A")
.addColumn("C")
.build();
对于我的 POJO
public class MyClass{
@JsonProperty("A")
private string a;
@JsonProperty("B")
private string b;
@JsonProperty("C")
private string c;
//getters setters
}
要获取 CSV 字符串,我这样做了:
List<MyClass> list = new MyClass();
MyClass row = new MyClass();
row.setA("Value A");
row.setB("Value B");
row.setC("Value C");
list.add(row);
ObjectWriter ow = mapper.writer(schema);
String csv = ow.writeValueAsString(list);
输出(带标题):
A,C
"Value A","Value C"