gpt4 book ai didi

javascript - 动态添加不同大小的数据集到Google Visualization Chart

转载 作者:行者123 更新时间:2023-11-28 07:00:22 26 4
gpt4 key购买 nike

我使用 simpleXML 循环数据。我正在寻找一种灵活的方法来循环数据以绘制 Google 图表。请记住,Google 图表的列数在任何阶段都会有所不同。

下面是我尝试在图表上绘制的数据示例。

<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 数组的函数。它需要一个二维数组,您可以为每个列标题/值使用内在值或文字对象。

第一部分构建列标题。使用该对象,您可以为 idlabeltype 分配值。 maybe others...

对于列值,该对象有两个键: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>

关于javascript - 动态添加不同大小的数据集到Google Visualization Chart,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32194220/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com