我无法让这个看似简单的代码工作。我有一个包含5行数据的csv文件,并试图从中创建一个气泡图!真的很感激,如果有人可以提供帮助!
<body>
<script type="text/javascript">
var diameter = 960,
format = d3.format(",d"),
color = d3.scale.category20c();
var bubble = d3.layout.pack()
.sort(null)
.size([diameter, diameter])
.padding(1.5);
var svg = d3.select("#svgid")
.append("svg")
.attr("width", diameter)
.attr("height", diameter)
.attr("class","bubble");
//Data
//var dataset = [ 5, 10, 15, 20, 25 ];
d3.text("http://bpgpuae.com/bil-rupeex.csv", function(csvData) {
var dataset = d3.csv.parse(csvData);
var node = svg.selectAll(".node")
.data(bubble.nodes(dataset))
.enter().append("g")
.attr("class", "node");
.attr("transform", function(d) { return "translate(" + d.x + "," + d.y + ")"; });
node.append("title")
.text(function(d) { return d.scam + ": " + format(d.funds); });
node.append("circle")
.attr("r", function(d) { return d.funds; })
.style("fill", function(d) { return color(d.decade); });
});
</script>
</body>
这是csv文件:
decade,scam,funds
2010s,NSEL scam,55
2010s,Railway Iron-Ore freight scam,170
2010s,Vodafone tax scam,110
2010s,Odisha Mining scam,600
2010s,DIAL Scam,1670
2010s,Tamil Nadu Granite scam,160
答案 0 :(得分:2)
包布局期待hierarchical data structure。因此,您必须相应地准备平面CSV数据。
var data = { name: "decade", children: csvData };
var node = vis.data([data]).selectAll("circle")
.data(pack.nodes)
...
这是一个有效的PLUNK,包含您的数据和大多数原始逻辑。