如何在JavaScript中将XML文件转换为CSV文件

6
<?xml version="1.0" encoding="UTF-8"?>
<current>
   <city id="1259229" name="Pune">
      <coord lon="73.86" lat="18.52" />
      <country>IN</country>
      <sun rise="2016-01-07T01:38:29" set="2016-01-07T12:42:53" />
   </city>
   <temperature value="27.49" min="27.49" max="27.49" unit="metric" />
   <humidity value="43" unit="%" />
   <pressure value="955.13" unit="hPa" />
   <wind>
      <speed value="2.65" name="Light breeze" />
      <gusts />
      <direction value="113.502" code="ESE" name="East-southeast" />
   </wind>
   <clouds value="36" name="scattered clouds" />
   <visibility />
   <precipitation mode="no" />
   <weather number="802" value="scattered clouds" icon="03d" />
   <lastupdate value="2016-01-07T06:25:45" />
</current>

我正在尝试将这个xml转换成csv格式。我已经尝试过像这样的一些方法,但是我没有得到任何将数据转换成csv格式的逻辑。

       try {
            var file : File = new File(dw.io.File.IMPEX + '/src/weather.csv');
            var fileWriter : FileWriter = new FileWriter(file, 'UTF-8');
            var csw : CSVStreamWriter = new CSVStreamWriter(fileWriter);
            csw.writeNext(//here I want array of string data );
            csw.writeEndDocument();
            csw.close();
            fileWriter.close();
        }
        catch(e) {
            return PIPELET_ERROR;
        }

但我不知道如何将XML数据转换为字符串数组


2
参见https://dev59.com/ZGsz5IYBdhLWcg3wWmjL,了解一种将XML解析为JavaScript对象的方法。然后您可以挑选出要放入数组中的部分。 - John Hascall
1个回答

4
由于您正在使用服务器端JavaScript,而且是DemandwareScript,请查看XMLStreamReader类和E4X语法。 https://en.m.wikipedia.org/wiki/ECMAScript_for_XML E4X是EcmaScript For Xml,一种专有语法,用于在Demandware中访问XML DOM。 您需要另一个File对象来读取XML文件。
此外,您的XML文件不是“平面”的,因此您需要定义哪些XML元素放在CSV中的哪个位置。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接