1

背景

使用 SimpleFlatMapper sfm-csv 6.0.3

示例 CSV:

|------|-------------|----------------|----------------|------------------|
| name | reference # | pf.first thing | pf.secondThing | pf.another.thing |
|======|=============|================|================|==================|
| foo  | eb2e23c0d6a | a value here   |                | another value    |
|------|-------------|----------------|----------------|------------------|
| bar  | 0a4bba4c1d0 | values         | all            | throughout       |
|------|-------------|----------------|----------------|------------------|

波乔

class Item {

    private String name;
    private String reference;
    private Map<String, String> prefixedFields;

    // ... builder, getters, etc.

}

简化代码

final CsvMapper<Item> mapper = CsvMapperFactory.newInstance()
    .addAlias("name", "itemName")
    .addAlias("reference #", "reference")
    .newMapper(Item.class);

return CsvParser.mapWith(mapper)
    .stream(file, items -> items.collect(List.collector()));

问题

照原样,Map正在回来null。我试图达到一个点:

firstRowItem.getPrefixedFields() == ImmutableMap.of(
    "first thing", "a value here",
    "another.thing", "another value")

secondRowItem.getPrefixedFields() == ImmutableMap.of(
    "first thing", "values",
    "secondThing", "all",
    "another.thing", "throughout")

“pf”。前缀是一成不变的,如果属性命名为“pf”,一切正常:

class Item {
    // ...
    private Map<String, String> pf;
    // ...
}

但我希望将该属性命名为“prefixedFields”而不是“pf”。

尝试解决

.addColumnProperty(
    col -> col.getName().startsWith("pf."),
    MapTypeProperty.KEY_VALUE)
  • .addAlias只接受String参数,所以这样的东西不起作用:
.addAlias("pf.", "prefixedFields")
4

1 回答 1

1

项目所有者对 GitHub 问题的评论让我走上了正轨。

addColumnProperty接受 的可变参数Object。您可以传入 a RenameProperty,它接受String用于简单列重命名的参数或Function<String, String> renameFunction. 像这样把它们放在一起:

final CsvMapper<Item> mapper = CsvMapperFactory.newInstance()
    .addAlias("name", "itemName")
    .addAlias("reference #", "reference")
    .addColumnProperty(
        column -> column.getName().startsWith("pf."),
        new RenameProperty(columnName -> columnName.replace("pf.", "prefixedFields_")))
    .newMapper(Item.class);
于 2019-04-05T18:42:58.257 回答