首页 > 解决方案 > 如何将复杂的 Java 对象写入 CSV 文件

问题描述

所以,我知道如何将一个简单的 Java 对象写入 CSV 文件,但是我在处理具有更复杂属性的 Java 对象时遇到了麻烦。以下是我目前拥有的示例:

人.java

public class Person {
    @CsvBindByName(column="name")
    private String name;

    @CsvBindByName(column="position")
    private String position;

    private AddressInfo info;

    // getters and setters ...

    // overridden toString method ...
}

地址信息.java

public class AddressInfo {
    @CsvBindByName(column="street")
    private String street;

    @CsvBindByName(column="city")
    private String city;

    @CsvBindByName(column="state")
    private String state;

    // getters and setters ...

    // overridden toString method ...
}

PersonWriter.java

public class PersonWriter {
    private static final Logger LOGGER = LoggerFactory.getLogger(PersonWriter.class);

    public static boolean writeCsVFromPerson(String directory, List<Person> persons) {
        File file = new File(directory + "/person-" + System.nanoTime() + ".csv");
        try {
            Writer writer = new FileWriter(file);
            MappingStrategy<Person> ms = new HeaderColumnNameMappingStrategy<Person>();
            ms.setType(Person.class);
            StatefulBeanToCsv<Person> sbc = new StatefulBeanToCsvBuilder<Person>(writer)
                    .withSeparator(CSVWriter.DEFAULT_SEPARATOR)
                    .withMappingStrategy(ms)
                    .build();
            sbc.write(persons);
            writer.close();
        } catch (Exception e) {
            LOGGER.error("Failed to create Person CSV file", e)            
        }
        return file.exists() && file.isFile();
    }
}

就创建有效的 CSV 文件(大部分情况下)而言,此方法有效,但 CSV 文件不包含任何 AddressInfo 属性。与此相反(从 CSV 读取到 Java 对象)工作得很好,所以我不完全确定我做错了什么。有没有人对此事有任何经验或知道我可能需要在这里纠正什么?

标签: javafilecsvnestedopencsv

解决方案


这在univocity-parsers中得到支持。只需使用@Nested注释,一切都会正确映射:

public class Person {

    @Parsed
    private String name;

    @Parsed
    private String position;

    @Nested
    private AddressInfo info;

}

要将这样的结构写入 CSV:

List<Person> persons = buildYourPersonList();
File file = new File(directory + "/person-" + System.nanoTime() + ".csv");
new CsvRoutines(settings).writeAll(persons, Person.class, file, "UTF-8");

希望这可以帮助。

免责声明:我是这个库的作者(Apache 2.0 许可证)


推荐阅读