Javascript 动态地将不同大小的数据集添加到Google Visulation图表
我使用simpleXML遍历数据。我正在寻找一种灵活的方法来循环数据,以便绘制谷歌图表。请记住,谷歌图表的列数在任何阶段都会有所不同 下面是我试图在图表上绘制的数据示例Javascript 动态地将不同大小的数据集添加到Google Visulation图表,javascript,php,arrays,xml,google-visualization,Javascript,Php,Arrays,Xml,Google Visualization,我使用simpleXML遍历数据。我正在寻找一种灵活的方法来循环数据,以便绘制谷歌图表。请记住,谷歌图表的列数在任何阶段都会有所不同 下面是我试图在图表上绘制的数据示例 <dealers> <dealer> <dealer>Sydney</dealer> <sales>265</sales> <year>2015 FY</year> </dealer>
<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>
记住,将来我们可能会有一个新的经销商,因此循环需要足够灵活,以将新经销商添加为一列,并相应地将值添加到行中的正确位置。同样如上面的示例数据所示,如果当年未指定任何值,则需要将0添加到行中。以下是我用于为
google.visualization.arrayToDataTable
构建数组的函数。它需要一个二维数组,您可以为每个列标题/值使用内在值或文字对象
第一部分构建列标题。使用该对象,可以为id
、label
和type
分配值
对于列值,对象有两个键:v
(值)和f
(格式化值)
var data=new google.visualization.arrayToDataTable(GetXmlDataArray(xmlObj),false);
函数GetXmlDataArray(发送方,参数){
var colArray;//列标题数组
var colHdr;//列标题
var colValue;//列值
var gglArray;//要返回的数组
var rowArray;//数据行数组
var nlItems;//xml列
var nlRows;//xml行
//init返回数组和列标题数组
阵列=[];
colArray=[];
//获取列标题xml节点
nlItems=sender.get_xml().selectNodes('//cog:item');
//生成列标题
对于(变量i=0;i
我正在使用的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>
基础知识
4886
DEF
4667
GHI
2892
...
以下是我用来为google.visualization.arrayToDataTable
构建数组的函数。它需要一个二维数组,您可以为每个列标题/值使用内在值或文字对象
第一部分构建列标题。使用该对象,可以为id
、label
和type
分配值
对于列值,对象有两个键:v
(值)和f
(格式化值)
var data=new google.visualization.arrayToDataTable(GetXmlDataArray(xmlObj),false);
函数GetXmlDataArray(发送方,参数){
var colArray;//列标题数组
var colHdr;//列标题
var colValue;//列值
var gglArray;//要返回的数组
var rowArray;//数据行数组
var nlItems;//xml列
var nlRows;//xml行
//init返回数组和列标题数组
阵列=[];
colArray=[];
//获取列标题xml节点
nlItems=sender.get_xml().selectNodes('//cog:item');
//生成列标题
对于(变量i=0;i 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;
}
<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>