将每个属性的单个bean rowise写入csv

时间:2018-04-25 09:00:56

标签: java csv opencsv

我正在使用opencsv,我有一个模型(假设Person有三个属性name, age, sex),我想存储到csv文件。

它应如下所示:

"name";"Jon";
"age";"30";
"sex";"male";

第一列包含属性名称,第二列包含值(如键值对)。

我的实现如下:

writer = new FileWriter("./settings.csv");

StatefulBeanToCsvBuilder<Person> beanToCsv = new StatefulBeanToCsvBuilder<SettingsModel>(writer);
StatefulBeanToCsv<SettingsModel> beanWriter = beanToCsv.build();
beanWriter.write(model);
writer.close();

我知道beanToCsv上有一些设置,但我不知道如何。

如果可能的话? 谢谢你的帮助:)

1 个答案:

答案 0 :(得分:3)

StatefulBeanToCsv具有将bean序列化为表格格式的标准方式。

你真正想要的是将bean展平为Key-Value对。因此,技巧应该使用BeanMap来保存Person bean数据。由于Person bean没有嵌套对象,我们可以简单地将其转换为ValueHolder.key和ValueHolder.value。

最终以这种方式应用此策略ColumnPositionMappingStrategy

ColumnPositionMappingStrategy<ValueHolder> strategy = new ColumnPositionMappingStrategy<>();
strategy.setType(ValueHolder.class);
strategy.setColumnMapping("key", "value");
FileWriter writer = new FileWriter("./settings.csv");
StatefulBeanToCsvBuilder<ValueHolder> csvBuilder = new StatefulBeanToCsvBuilder<>(writer);
StatefulBeanToCsv<ValueHolder> beanWriter = csvBuilder.withSeparator(';').withMappingStrategy(strategy).build();
beanWriter.write(content);
writer.close();

可以访问完整的工作样本here