CSV naar XML
Code (php)
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
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
<?php
function csv2xml($file, $container = 'data', $rows = 'row')
{
$r = "<{$container}>\n";
$row = 0;
$cols = 0;
$titles = array();
$handle = @fopen($file, 'r');
if (!$handle) return $handle;
while (($data = fgetcsv($handle, 1000, ',')) !== FALSE)
{
if ($row > 0) $r .= "\t<{$rows}>\n";
if (!$cols) $cols = count($data);
for ($i = 0; $i < $cols; $i++)
{
if ($row == 0)
{
$titles[$i] = $data[$i];
continue;
}
$r .= "\t\t<{$titles[$i]}>";
$r .= $data[$i];
$r .= "</{$titles[$i]}>\n";
}
if ($row > 0) $r .= "\t</{$rows}>\n";
$row++;
}
fclose($handle);
$r .= "</{$container}>";
return $r;
}
$xml .= csv2xml('demo.csv', 'leden');
echo $xml;
?>
function csv2xml($file, $container = 'data', $rows = 'row')
{
$r = "<{$container}>\n";
$row = 0;
$cols = 0;
$titles = array();
$handle = @fopen($file, 'r');
if (!$handle) return $handle;
while (($data = fgetcsv($handle, 1000, ',')) !== FALSE)
{
if ($row > 0) $r .= "\t<{$rows}>\n";
if (!$cols) $cols = count($data);
for ($i = 0; $i < $cols; $i++)
{
if ($row == 0)
{
$titles[$i] = $data[$i];
continue;
}
$r .= "\t\t<{$titles[$i]}>";
$r .= $data[$i];
$r .= "</{$titles[$i]}>\n";
}
if ($row > 0) $r .= "\t</{$rows}>\n";
$row++;
}
fclose($handle);
$r .= "</{$container}>";
return $r;
}
$xml .= csv2xml('demo.csv', 'leden');
echo $xml;
?>
En dit CSV bestand: http://dl.dropbox.com/u/2512912/demo.csv
Maar ik krijg geen output, en ook geen error's...
Wat is er fout?
Ik heb het script even overgenomen op mijn eigen server en er een beetje mee gespeeld. Je gaat er van uit dat $data een array vormt (zie regel 20) maar dit is niet het geval.
Ik heb het volgende bovenaan in de while-lus gezet:
Dan zie je dat je niet met een array te maken hebt maar met een enkele string die gescheiden is in puntkomma's. Probeer die eens uit elkaar te pluizen met explode().
Overigens zie je helemaal niets omdat je (volgens de browser) waarschijnlijk HTML tags aan het uitprinten bent. Zet onderaan je script om te testen maar het volgende: