动态添加不同大小的数据集到谷歌可视化图表
Dynamically add different sized data sets to Google Visulation Chart
我使用simpleXML循环遍历数据。我正在寻找一种灵活的方式来循环通过绘制谷歌图表的目的的数据。请记住,Google Chart的列数在任何阶段都会有所不同。
下面是我试图在图表上绘制的数据样本。
<dealers>
<dealer>
<dealer>Sydney</dealer>
<sales>265</sales>
<year>2015 FY</year>
</dealer>
<dealer>
<dealer>Sydney</dealer>
<sales>218</sales>
<year>2016 FY</year>
</dealer>
<dealer>
<dealer>Melbourne</dealer>
<sales>143</sales>
<year>2016 FY</year>
</dealer>
<dealer>
<dealer>Brisbane</dealer>
<sales>181</sales>
<year>2016 FY</year>
</dealer>
</dealers>
我如何循环通过它来生成下面的图表?
var data = google.visualization.arrayToDataTable([
['Year', 'Sydney', 'Melbourne', 'Brisbane'],
['2015 FY', 265, 0, 0],
['2016 FY', 218, 143, 181]
]);
请记住,将来我们可能会有一个新的经销商,因此循环需要足够灵活,以便将新的经销商添加为一列,并相应地将值添加到行中正确的位置。同样,如上面的示例数据所示,如果没有为该年份指定值,则需要向行添加一个0。
这是我用来为google.visualization.arrayToDataTable
构建数组的函数。它需要一个二维数组,您可以为每个列标题/值使用固有值或文字对象。
第一部分构建列标题。使用该对象,您可以为id
、label
和type
赋值。也许其他人…
对于列值,对象有两个键:v
(值)和f
(格式化值)。
var data = new google.visualization.arrayToDataTable(GetXmlDataArray(xmlObj), false);
function GetXmlDataArray(sender, args) {
var colArray; // column heading array
var colHdr; // column heading
var colValue; // column value
var gglArray; // array to be returned
var rowArray; // data row array
var nlItems; // xml columns
var nlRows; // xml rows
// init return array and column heading array
gglArray = [];
colArray = [];
// get columns heading xml nodes
nlItems = sender.get_xml().selectNodes('//cog:item');
// build column headings
for (var i = 0; i < nlItems.length; i++) {
// column literal
colHdr = {};
colHdr.id = 'column_' + i;
colHdr.label = nlItems[i].getAttribute('name');
// check data type
switch(nlItems[i].getAttribute('type')) {
case 'xs:double':
colHdr.type = 'number';
break;
case 'xs:dateTime':
colHdr.type = 'datetime';
break;
default:
colHdr.type = 'string';
}
// add column
colArray.push(colHdr);
}
// add column headings to return array
gglArray.push(colArray);
// get column value xml nodes
nlRows = sender.get_xml().selectNodes('//cog:row');
// build data rows
for (var i = 0; i < nlRows.length; i++) {
// init row array
rowArray = [];
// process each column
for (var x = 0; x < nlRows[i].childNodes.length; x++) {
// check if column is null
if (nlRows[i].childNodes[x].getAttribute('xs:nil')) {
colValue = null;
} else {
// set the text value, depends on the browser
colValue = nlRows[i].childNodes[x].text || nlRows[i].childNodes[x].textContent;
}
// check the data type
switch(colArray[x].type) {
// format date columns
case 'datetime':
// ensure there is a value
if (colValue) {
// set date value
colValue = new Date(colValue);
// add column value to row array
rowArray.push({
v: colValue, // column value
f: colValue.toLocaleString() // column formatted value
});
} else {
rowArray.push(colValue);
}
break;
default:
// add column value to row array, no object needed
rowArray.push(colValue);
}
}
// add column values to return array
gglArray.push(rowArray);
}
return gglArray;
}
我使用的XML看起来像这样…
<dataset>
<metadata>
<item name="Site" type="xs:string" length="18"/>
<item name="ID" type="xs:double" precision="2"/>
</metadata>
<data>
<row>
<value>ABC</value>
<value>4886</value>
</row>
<row>
<value>DEF</value>
<value>4667</value>
</row>
<row>
<value>GHI</value>
<value>2892</value>
</row>
...
</data>
</dataset>
相关文章:
- 如何在谷歌可视化中组合数字和模式格式化程序
- 如何使用图表包装函数有条件地格式化谷歌可视化表单元格
- 从特定系列的谷歌可视化折线图中删除悬停工具提示
- 谷歌可视化数据表间歇性问题
- 如何修复谷歌可视化-材料线中的重叠问题
- 以编程方式透视谷歌可视化数据表
- 在谷歌可视化饼图中突出显示一个切片
- 谷歌可视化数据分组字符串列
- 谷歌可视化树图-如何创建自定义文本
- 如何在谷歌可视化api柱状图中使用的json对象内用数字替换字符串值
- 如何在谷歌分析中跟踪谷歌可视化图表事件
- 删除谷歌可视化饼图中的图例
- IE8谷歌可视化权限被拒绝
- 更改谷歌图表(谷歌可视化)图形的背景颜色
- 用javascript隐藏谷歌可视化列
- 加载旧版本的谷歌可视化库
- 为什么我之前工作的谷歌可视化图表在2013年11月26日之后停止工作
- 谷歌可视化时间轴图表日期奇怪地休息了一个月…我错过了什么
- 谷歌可视化时间线显示鼠标光标的时间
- 谷歌可视化目标线