2

我有一个代表分层树数据的 CSV:

industry,level1,level2,level3,name
Ecommerce,Web,,,Rakuten
Ecommerce,Crowdsourcing,,,Lancers
Social,Photo sharing,Deco apps,,Snapeee
Social,Photo sharing,Deco apps,Collage apps,DecoAlbum
Portals,,,,Yahoo Japan

level1...level3代表子节点,行name代表底部节点。我正在尝试应用d3.nest()函数来获取分层 JSON 对象。特别是,我想摆脱级别行为空的节点。到目前为止,我有以下代码:

d3.csv("data.csv", function(rows) {
  sunburst_tree = d3.nest()
    .key(function(d) { return d.industry; })
    .key(function(d) { return d.level1; })
    .key(function(d) {  if (!(typeof d.level2 === 'undefined')) return d.level2; })
    .entries(rows);

  console.log(sunburst_tree);
});

这会产生带有空键的 JSON 对象,如下所示:

{"key":"Portals",
"values":[{"key":"",
    "values":[{"key":"",
        "values":[{"industry":"Portals","level1":"","level2":"","level3":"","name":"Yahoo Japan"}]
        }]
    }]
}

相反,我想删除所有空子节点:

{"key":"Portals",
    "values":[{"industry":"Portals",
               "level1":"","level2":"","level3":"","name":"Yahoo Japan"}]}
}

如何做到这一点?

4

1 回答 1

0

你想拥有多个钥匙吗?似乎在您想要的格式中,您只有一个键。

如果您不想要多个键,则应删除定义键的函数,

或者

如果您确实需要多个密钥,我建议您在使用函数生成密钥之前使用 if 子句。并检查空字符串为

d.level1 === "" 

应该有帮助。

于 2013-07-24T18:47:54.283 回答