我正在尝试将我的 csv 转换为 nvd3 的堆叠面积图所需的格式:http://nvd3.org/ghpages/stackedArea.html但 在数组转换中迷路了。有人可以帮忙吗?
csv: 长度,m1,m2,m3,m4 9,1,2,3,4 99,11,22,33,44 999,111,222,333,444
nvd3需要的格式
var histcatexplong = [{“键”:“消费者酌情”,“值”:[[0000000000000,27.38478809681],[000000000000000,27.371377218208],[0000000000000,27.371377218208],[00000000000000000000000,26.82341151939393939,,; " : [ [ 0000000000000 , 27.45458809681] , [ 0000000000000 , 27.444444444408] , [ 0000000000000 , 26.455555555395] } ,
所以如果转换正确,我应该得到: var myall = [ { "key" : "m3" , "values" : [ [ 9 , 3] , [ 99, 33] , [ 999, 333] } , { "键”:“m1”,“值”:[ [ 9 , 1] , [ 99, 11] , [ 999, 111] } ,
我的转换代码:
d3.csv("s1.csv", function (csv) {
var myall = [
{
"key" : "m3",
"values" : []
},
{
"key" : "m2",
"values" : []
}
];
v3 = csv.map(function(d) { return [ +d["length"], +d["m3"] ]; });
v2 = csv.map(function(d) { return [ +d["length"], +d["m2"] ]; });
d3.keys(csv).forEach(function(d) {
myall[0].values.push(v3);
myall[1].values.push(v2);
});
console.log(myall);
问题是 myall 没有出现在 DOM 中(控制台输出似乎缺少顶层层次结构:
[Object { key="m345", values=[249]}, Object { key="m2", values=[249]}]
对于 nvd3 堆积面积图示例,为 histcatexplong var 进行 DOM 复制/粘贴:
*histcatexplong
[Object { key="Consumer Discretionary", values=[77]}, Object { key="Consumer Staples", values=[77]}, Object { key="Energy", values=[77]}, 7 more...]*
谢谢。