使用PowerShell下载XML,并另存为CSV文件?

时间:2009-06-30 12:18:39

标签: xml powershell csv

我是PowerShell的新手,但拥有强大的C#背景。

我要完成的任务是下载一些XML,然后将一些XML文件中的元素保存在.csv文件中。我不需要XML中的所有元素,只需要几个项目。

XML看起来像这样:

<result>
  <case>
    <InputData>
      <Id>1</Id>
      <Firstname>John</Firstname>
      <Lastname>Smith</Lastname>
      <....lots more properties and subnodes I don't need>
    </InputData>
  </case>
</result>

我设法使用以下内容下载XML:

$downloaded = ([Xml](New-Object Net.WebClient).DownloadString("http://url.to.server/file.xml"))

现在我需要从XML中提取一些属性,并将其导出到CSV文件。

据我所知,我可以使用$ downloaded.result.case [0] .InputData.Firstname访问数据,但需要一些有关如何提取一些属性并保存为CSV的建议。

2 个答案:

答案 0 :(得分:4)

你可以做点什么:

$downloaded.result.case | %{ $_.InputData }`
| select Firstname,Lastname `
| Export-Csv -path foo.csv -NoTypeInformation

答案 1 :(得分:0)

当将XML转换为其他东西时,XSLT是一种(?)标准方法。

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <xsl:output method="text" />

  <xsl:template match="InputData">
    <xsl:value-of select="concat('"', Id, '"')" />
    <xsl:value-of select="','" />
    <xsl:value-of select="concat('"', Firstname, '"')" />
    <xsl:value-of select="','" />
    <xsl:value-of select="concat('"', Lastname, '"')" />
    <xsl:value-of select="&#10;" />
  </xsl:template>

</xsl:stylesheet>

一些Powershell背景:www.hanselman.com: XSLT with Powershell