我有以下格式的 Google DataTable:
+----------+-------+--------+
| time | label | values |
+----------+-------+--------+
| 12345678 | foo | 100 |
| 12345678 | bar | 200 |
| 12345700 | foo | 150 |
| 12345700 | bar | 350 |
... ... ...
我需要创建一个折线图,每个不同的“标签”有一条线,X 轴上的时间和 Y 轴上的值。
据我所知,这要求 DataTable 采用以下格式:
+----------+-----+-----+
| time | foo | bar |
+----------+-----+-----+
| 12345678 | 100 | 200 |
| 12345700 | 150 | 350 |
... ... ...
我要么需要一种将 DataTable 旋转成这种形状的方法,要么需要一种在不修改原始 DataTable 的情况下绘制我想要的 LineChart 的方法。
附录
我可以很容易地创建一个这种形状的 DataTable,如下所示:
var newDataTable = new google.visualization.DataTable();
newDataTable.addColumn("number", "time");
var distinctLabels = oldDataTable.getDistinctValues(1);
for (var i = 0; i < distinctLabels.length; i++)
{
newDataTable.addColumn("number", distinctLabels[i]);
}
但接下来的挑战是填充这张表。由于新表中单行的数据存在于第一个表的多行中,因此我不能简单地遍历旧表的每一行调用.addRow()
新表
我可以利用哈希表或其他一些复杂的结构来解析数据并使用它,但是:
- 这似乎是一个有更简单解决方案的问题
- 我想要尽可能好的性能,因为每次有人与页面上的 UI 元素交互时都需要重新绘制此 LineChart