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データを配列の文字列に変換する方法がわかりません

4

1 に答える 1

4

サーバーサイド JavaScript、さらに DemandwareScript を使用しているため、XMLStreamReader クラスと E4X 構文を確認してください。https://en.m.wikipedia.org/wiki/ECMAScript_for_XML E4X は EcmaScript For Xml であり、Demandware で XML DOM アクセスに使用される独自の構文です。XML ファイルを読み取るには、もう 1 つの File オブジェクトが必要です。

また、XML ファイルは「フラット」ではないため、どの XML 要素を CSV のどこに配置するかを定義する必要があります。

于 2016-01-08T08:39:24.860 に答える