将函数应用于数组的每个元素

时间:2014-07-08 07:04:30

标签: javascript d3.js

我的数据格式为

var JSONData = [
        {"id": "Line1", "x_data": ["2005-01-01 01:00", "2005-01-01 02:00", "2005-01-01 03:00", "2005-01-01 04:00", "2005-01-01 05:00"], "y_data": [1, 2, 3, 4, 5]},
        {"id": "Line2", "x_data": ["2005-01-01 01:00", "2005-01-01 02:00", "2005-01-01 03:00", "2005-01-01 04:00", "2005-01-01 05:00"], "y_data": [6, 7, 8, 9, 10]},
        {"id": "Line3", "x_data": ["2005-01-01 01:00", "2005-01-01 02:00", "2005-01-01 03:00", "2005-01-01 04:00", "2005-01-01 05:00"], "y_data": [11, 12, 13, 1, 15]}
    ]

并希望使用y数据压缩x数据,并将日期解析函数应用于返回的数组数组的每个x元素。

我尝试了以下内容,但它返回了未定义的数组。

var parseDate = d3.time.format("%Y-%m-%d %H:%M").parse;
    var nested = d3.nest()
            .key(function(d) {
                return d.name;
            })
            .map(JSONData)
    console.log("nested ", nested);
    var keyring = d3.keys(nested).filter(function(key) {
        return (key !== "x_data" && key !== "y_data");
    });
    console.log("keyring ", keyring);
    var transpose = keyring.map(function(name) {
            console.log("name ", name);
            return {
                name: name,
                values: nested[name].map(function(d) {
                    var zip_data = d3.zip(d.x_data, d.y_data).forEach(function(d, i) {
                        d[0] = parseDate(d[0]);
                        d[1] = +d[1];
                    });
                    console.log("zip data ", zip_data);
                    return zip_data;
                })
            };
        });

感谢您的帮助。

1 个答案:

答案 0 :(得分:1)

试试这个。

var parseDate = d3.time.format("%Y-%m-%d %H:%M").parse;
var requiredArray= JSONData.map(function(d) { 
               var parsedX = d.x_data.map(function(date){ return parseDate(date) });
               return d3.zip(parsedX , d.y_data) 
            });