我有一个表示分层树数据的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"}]}
}如何做到这一点?
发布于 2013-07-25 02:47:54
你想拥有多个密钥吗?在您想要的格式中,您似乎只有一个密钥。
如果你不想要多个键,你应该删除定义键的函数,
或
如果您确实需要多个键,我建议您在使用函数生成键之前使用if子句。并检查空字符串是否为
d.level1 === "" 应该会有帮助。
https://stackoverflow.com/questions/16907609
复制相似问题