我想使用 jackson CsvMapper 将 Pojos 序列化/反序列化为 csv 格式。我的pojos:
public class User implements Serializable {
String name;
@JsonUnwrapped(prefix = "||")
Role role;
String email;
}
public class Role implements Serializable {
Long id;
String name;
}
Run Code Online (Sandbox Code Playgroud)
我现在得到的:
name|email|||id|||name
New User|newuser@gmail.com|1|User
New User2|newuser2@gmail.com|1|User
New User3|newuser3@gmail.com|1|User
Run Code Online (Sandbox Code Playgroud)
我期望获得以下分隔符的内容:
New User|newuser@gmail.com|||1|User
Run Code Online (Sandbox Code Playgroud)
(只有用附加分隔符分隔的嵌套对象,而不是其字段,分隔符也必须应用于数据,而不仅仅是标题)此外,我需要在行内移动嵌套对象。例如预期结果:
New User|||1|User|||newuser@gmail.com
Run Code Online (Sandbox Code Playgroud)
我当前的架构和序列化代码:
CsvSchema userSchema = csvMapper
.schemaFor(User.class)
.sortedBy("name", "role.name", "role.id", "email")
.withoutQuoteChar()
.withColumnReordering(true)
.withColumnSeparator('|')
.withHeader();
csvMapper.writer(userSchema).writeValueAsString(users);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2094 次 |
| 最近记录: |