Tutorial : Convert a table to XML
by toy
Javascript file
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57 function getXMLFromArrays( h , v )
{
var xmlStr = '<Data>';
for( var k = 0 ; k < v.length ; k++ )
{
xmlStr += '<Row>';
for( var l = 0 ; l < h.length ; l++ )
{
xmlStr += '<' + h[ l ].innerHTML + '>';
xmlStr += v[ k ][ l ];
xmlStr += '</' + h[ l ].innerHTML + '>';
}
xmlStr += '</Row>';
}
xmlStr += '</Data>';
return xmlStr;
}
function getHeaders( trs )
{
var headers = trs[0];
var tds = headers.getElementsByTagName( 'td' );
return tds;
}
function initialArray( arr )
{
for( var i = 0 ; i < arr.length ; i++ )
{
arr[ i ] = new Array();
}
return arr;
}
function extract( table_id )
{
var table = document.getElementById( table_id );
var trs = table.getElementsByTagName( 'tr' );
var headers = getHeaders( trs );
var myTds = new Array( trs.length - 1 );
myTds = initialArray( myTds );
for( var i = 1 ; i < trs.length ; i++ )
{
var tds = trs[ i ].getElementsByTagName( 'td' );
for( var j = 0 ; j < tds.length ; j++ )
{
myTds[ i - 1 ].push( tds[ j ].innerHTML );
}
}
return getXMLFromArrays( headers , myTds );
}
function printXML()
{
console.log( extract( 'table' ) );
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27 <body>
<p>
<input value="Extract!" type="button" onclick="printXML();" />
</p>
<table id="table" border="1">
<tr>
<td>Header1</td>
<td>Header2</td>
</tr>
<tr>
<td>Value1</td>
<td>Value2</td>
</tr>
<tr>
<td>Value3</td>
<td>Value4</td>
</tr>
<tr>
<td>Value5</td>
<td>Value6</td>
</tr>
<tr>
<td>Value7</td>
<td>Value8</td>
</tr>
</table>
</body>
Twitter
Facebook