据称d3没有采用任何特定的数据fromat,无论它是json还是csv。但我注意到一些奇怪的行为。折叠式树状分层结构d3
在这个例子中http://bl.ocks.org/mbostock/4339083,输入文件是JSON所以
d3.json("/d/4063550/flare.json", function(error, flare) {
root = flare;
root.x0 = height/2;
root.y0 = 0;
function collapse(d) {
if (d.children) {
d._children = d.children;
d._children.forEach(collapse);
d.children = null;
}
}
root.children.forEach(collapse); //?
update(root);
});
在这种example,它是装载
d3.csv("FederalBudget_2013_a.csv", function(csv) {
var data=[];
//Remove all zero values nodes
csv.forEach(function (d) {
var t=0;
for (var i=0; i < sumFields.length; i++) {
t+= Number(d[sumFields[i]]);
}
if (t > 0) {
data.push(d);
}
})
var nest = d3.nest()
.key(function(d) { return d.Level1; })
.key(function(d) { return d.Level2; })
.key(function(d) { return d.Level3; })
.entries(data);
root={};
root.values=nest;
root.x0 = h/2;
root.y0 = 0;
var nodes = tree.nodes(root).reverse(); //?
tree.children(function (d){ return d.children;}); //?
update(root);
});
请澄清为何有不同的方法csv文件我在哪里放置了一个quesiton标记。我试图在第二个例子中看到孩子们,但是没有任何回报。 谢谢。
谢谢你的回应!我非常重视您的博客以了解,这非常有用!看起来(为了让生活更简单),我们应该尝试在JSON父/子层次结构中格式化数据,而不是使用csv?除了Brightpoint示例以外,我还没有看到关于csv的许多文档以及树层次结构。 – user1896196
理想的情况下,如果可能的话,json将是值得的努力,但有时我们没有得到选择:-)。如果答案是合适的,不要忘记接受它:-)。 – d3noob