Univocity - 将列表属性写入多行

时间:2017-10-08 04:24:06

标签: java univocity

我有一个bean Person,其List为“memberOf”。现在我想要的是,每个“memberOf”条目写一行这个bean(项目需要它)。我的所有代码都写在bean周围,但我遇到了这个问题。例如:

public class Person {
    @Parsed(field = "USR_USERID")
    private String uid;
    @Parsed(field = "USR_NSUNIQUEID")
    private String nsUniqueID;

    @Parsed(field = "GROUP_NAME")
    List<String>isMemberOf;
    //-- Getters and Setters...
}

使用CsvWriterSettings和BeanWriterProcessor我在csv中得到的结果如下:

"uid","nsuniqueId","[memberOf1, memberOf2...]"

但我想要的是:

"uid","nsuniqueId","memberOf1"
"uid","nsuniqueId","memberOf2"

使用BeanWriterProcessor时有没有办法做到这一点?

由于

1 个答案:

答案 0 :(得分:0)

图书馆的作者在这里。虽然图书馆不支持您想要做的事情,但它的工作相对容易 - 以下示例有点糟糕,但会做您想做的事。

基本上,您可以注释班级的方法。使用它来创建一个方法,每次调用它时都会返回isMemberOf的元素。例如:

    private int groupNameIndex = 0;

    @Parsed(field = "GROUP_NAME")
    public String nextGroupName() {
        if (hasMoreGroups()) {
            return isMemberOf.get(groupNameIndex++);
        }
        return null;
    }

    public boolean hasMoreGroups() {
        return isMemberOf != null && groupNameIndex < isMemberOf.size();
    }

然后你可以一遍又一遍地写同一个bean,直到hasMoreGroups返回false

    while (person.hasMoreGroups()) {
        writer.processRecord(person);
    }

我以前用来测试的代码:

public static void main(String... args) {
    Person person = new Person();
    person.uid = "XYZ";
    person.nsUniqueID = "abc";
    person.isMemberOf.add("group1");
    person.isMemberOf.add("group2");
    person.isMemberOf.add("group3");

    StringWriter out = new StringWriter();

    CsvWriterSettings settings = new CsvWriterSettings();
    settings.setHeaderWritingEnabled(true);
    settings.setRowWriterProcessor(new BeanWriterProcessor<Person>(Person.class));

    CsvWriter writer = new CsvWriter(out, settings);

    while (person.hasMoreGroups()) {
        writer.processRecord(person);
    }
    writer.close();

    System.out.println(out.toString());
}

输出:

USR_USERID,USR_NSUNIQUEID,GROUP_NAME
XYZ,abc,group1
XYZ,abc,group2
XYZ,abc,group3

希望有所帮助