如何将复杂 Java 对象写入 CSV 文件
How to Write Complex Java Object to CSV File
所以,我知道如何将简单的 Java 对象写入 CSV 文件,但我在处理具有更复杂属性的 Java 对象时遇到了问题。以下是我目前拥有的示例:
Person.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 ...
}
AddressInfo.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 对象)工作得很好,所以我不完全确定我做错了什么。有没有人对此事有任何经验或知道我可能需要在这里纠正什么?
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 许可证)
所以,我知道如何将简单的 Java 对象写入 CSV 文件,但我在处理具有更复杂属性的 Java 对象时遇到了问题。以下是我目前拥有的示例:
Person.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 ...
}
AddressInfo.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 对象)工作得很好,所以我不完全确定我做错了什么。有没有人对此事有任何经验或知道我可能需要在这里纠正什么?
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 许可证)