我正在尝试按照博斯托克关于城市和温度的示例将多条折线图制作成一个。
示例就在这里http://bl.ocks.org/mbostock/3884955
现在,我有一个根据世界数据库信息定制的 tsv 文件。格式如下
Country Name Year GDP Population GDP per Capita Exports Industry
Brazil 2004 663760341880.342 184010283 3607.1915713555 16.4250921582 30.1135838508
Brazil 2005 882185702547.247 186142403 4739.3054367481 15.1283508131 29.27296088
Brazil 2006 1088916819852.94 188134315 5787.9755740091 14.3684508393 28.7527649158
Brazil 2007 1366853244424.28 189996976 7194.0789437843 13.3643803148 27.8112224671
Brazil 2008 1653538618144.8 191765567 8622.7086750397 13.6631968034 27.901606309
Brazil 2009 1620165226993.77 193490922 8373.3397424907 10.9789949015 26.8288327492
Brazil 2010 2143035333258.24 195210154 10978.093553772 10.8715851234 28.0694513261
Brazil 2011 2476652189879.72 196935134 12575.9794079188 11.8891676714 27.5330208705
Brazil 2012 2252664120777.39 198656019 11339.5211084814 12.557350455 26.2886840461
我在不同年份有多个国家/地区的输入。格式是根据此处另一个帖子问题的答案的建议
此 TSV 文件用于在单独的 svg 图表上绘制 GDP、人口等;为方便起见,我将其放入一个 tsv 文件中。现在,我的下一步是从我的数据中提取国家并将它们绘制成线条。该示例将城市作为标题行中的键,由 d3.keys 调用解析。但是,我的国家/地区位于一个名为 Country Name 的键中,如上所示。我将如何解析我的数据,以便为每个国家/地区获得一条线?
这是我目前在编码方面的情况
//Define Margin Object with properties from the four sides Clockwise
var margin = {top: 20, right: 80, bottom: 30, left: 50};
var dataset;
//Width and Height as inner dimensions of chart area
var width = 960 - margin.left - margin.right;
var height = 500 - margin.top - margin.bottom;
//Define svg
var svg = d3.select("#chart").append("svg")
.attr("width", width + margin.left + margin.right)
.attr("height", height + margin.top + margin.bottom)
.append("g")
.attr("transform", "translate(" + margin.left + "," + margin.top + ")");
var x = d3.scale.linear()
.range([0, width]);
var y = d3.scale.linear()
.range([0, height]);
var color = d3.scale.category10();
var xAxis = d3.svg.axis()
.scale(x)
.orient("bottom");
var yAxis = d3.svg.axis()
.scale(y)
.orient("left");
var line = d3.svg.line()
.interpolate("basis")
.x(function(d) {return x(d.year);})
.y(function(d) {return y(d.GDP);});
d3.tsv("OlympicsData.tsv", function(error, data) {
x.domain(d3.extent(data, function(d) {return d["Year"];}));
y.domain(d3.extent(data, function(d) {return d["GDP"];}));
console.log(d3.min(data, function(d) {return d["Year"];}) + " " + d3.max(data, function(d) {return d["Year"];}));
svg.append("g")
.attr("class", "x axis")
.call(xAxis);
svg.append("g")
.attr("class", "y axis")
.call(yAxis);
});