Ajax 使用json输入的Google可视化

Ajax 使用json输入的Google可视化,ajax,json,google-visualization,Ajax,Json,Google Visualization,作为一名初学者,我正在努力使用谷歌可视化从JSON文件输入制作图表。我搜索过类似的问题,但我不确定它是否有用 我有一组JSON格式的数据。目前它是静态数据,存储在本地。我想加载数据并使用Google可视化将其可视化。我的数据如下: "rows":[{"Time":10:00:00,"Lat":53.02900044,"Long":7.44578671,"Altitude":57,"Speed":0,...}, {"Time": 11:00:00,"Lat":52.06000044,"L

作为一名初学者,我正在努力使用谷歌可视化从JSON文件输入制作图表。我搜索过类似的问题,但我不确定它是否有用

我有一组JSON格式的数据。目前它是静态数据,存储在本地。我想加载数据并使用Google可视化将其可视化。我的数据如下:

     "rows":[{"Time":10:00:00,"Lat":53.02900044,"Long":7.44578671,"Altitude":57,"Speed":0,...}, {"Time": 11:00:00,"Lat":52.06000044,"Long":7.54578671,"Altitude":53,"Speed":12,...]}
我试着用这种方式:

    function init () {

var json3 = (function () {
    var json3 = [];
    $.ajax({
        'async': false,
        'global': false,
        'url': "Person3.json",
        'dataType': "json",
        'success': function (data3) {
            json3 = data3.rows;
        }
    });
    console.log("Number of message rows: " + json3.length);
    return json3;
})();
var readings3 = [];
if (json3.length > 0)
    var readings3 = json3;
    else
    readings3=[
        {"Time":"10:00:00 ","Lat":66.02794563,"Long":7.45527353,.....},
        {"Time":"13:40:52 ","Lat":66.16435456,"Long":7.98108809,......}
        ]
var data3 = new google.visualization.DataTable(readings3);

var graphview = new google.visualization.ChartWrapper({
    chartType: 'LineChart',
    containerId: 'visualization1',

    dataTable: data3,
options: {
        // chart options
    }
});

graphview.draw();    
}
google.load('visualization', '1', {packages:  ['corechart'], callback: init});
有没有人能帮助我这里缺少什么,或者如果你看到类似的问题正在得到解决。
提前感谢…

DataTable构造函数将不接受具有该结构的对象;您必须手动将该对象解析为数据表:

var data3 = new google.visualization.DataTable();
data3.addColumn('timeofday', 'Time');
data3.addColumn('number', 'Lat');
data3.addColumn('number', 'Long');
//...
for (var i = 0; i < readings3.length; i++) {
    var match = readings3[i].Time.match(/(\d{2}):(\d{2}):(\d{2})/);
    var hours = parseInt(match[1], 10);
    var minutes = parseInt(match[2], 10);
    var seconds = parseInt(match[3], 10);
    data.addRow([[hours, minutes, seconds, 0], readings3[i].Lat, readings3[i].Long, /* ... */]);
}

此外,如果不是复制/粘贴错误,则需要引用JSON字符串中的时间,因为时间:10:00:00无效。

您好,这是完美的!!!谢谢您知道同样的方法是否也适用于动态实时JSON数据吗?是的,您可以采用同样的方法。若您的键将从一个数据集更改为另一个数据集,那个么您应该为列构造包含一些元数据,这样您也可以动态地构建这些元数据。