我正在尝试将xml文件的节点显示到表中,我的问题是每列显示为数组而不是列表。我不知道如何将节点转换为列表..
我的结果应该是:
CCI, Description
CCI-000001, BLAH BLAH BLAH BLAH BLAH BLAH
CCI-000002, BLAH BLAH BLAH BLAH BLAH BLAH
CCI-003391, BLAH BLAH BLAH BLAH BLAH BLAH
取而代之的是:
CCI Description
{CCI-000001, CCI-000002, CCI-003391} {BLAH BLAH BLAH BLAH BLAH ...}
我的xml文件是
<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type='text/xsl' href='cci2html.xsl'?>
<cci_list xmlns="http://iase.disa.mil/cci">
<metadata>
<version>2013-10-08</version>
<publishdate>2013-10-08</publishdate>
</metadata>
<cci_items>
<cci_item id="CCI-000001">
<status>draft</status>
<publishdate>2013-01-01</publishdate>
<contributor>DISA FSO</contributor>
<definition>BLAH BLAH BLAH BLAH BLAH BLAH</definition>
<type>policy</type>
<references>
<reference creator="NIST" title="NIST SP 800-53" version="3" location="NIST" index="AC-1 a" />
<reference creator="NIST" title="NIST SP 800-53A" version="1" location="NIST" index="AC-1.1 (i&ii)" />
<reference creator="NIST" title="NIST SP 800-53 Revision 4" version="4" location="NIST" index="AC-1 a 1" />
</references>
</cci_item>
<cci_item id="CCI-000002">
<status>draft</status>
<publishdate>2013-01-01</publishdate>
<contributor>DISA FSO</contributor>
<definition>BLAH BLAH BLAH BLAH BLAH </definition>
<type>policy</type>
<references>
<reference creator="NIST" title="NIST SP 800-53" version="3" location="NIST" index="AC-1 a" />
<reference creator="NIST" title="NIST SP 800-53A" version="1" location="NIST" index="AC-1.1 (iii)" />
<reference creator="NIST" title="NIST SP 800-53 Revision 4" version="4" location="NIST" index="AC-1 a 1" />
</references>
</cci_item>
<cci_item id="CCI-003391">
<status>draft</status>
<publishdate>2013-01-01</publishdate>
<contributor>DISA FSO</contributor>
<definition>BLAH BLAH BLAH BLAH BLAH BLAH</definition>
<type>policy</type>
<references>
<reference creator="NIST" title="NIST SP 800-53 Revision 4" version="4" location="NIST" index="SA-19 (3)" />
</references>
</cci_item>
</cci_items>
</cci_list>
我的代码是
[xml]$data = GC "file.xml"
$CCInum = $data.cci_list.cci_items.cci_item.id
$CCIdescription = $data.cci_list.cci_items.cci_item.definition
$CCItable = New-Object PSobject -Property @{
CCI = $CCInum
Description = $CCIdescription
}
$CCItable | select CCI, Description
我这样做是因为我最终会将结果导出到csv文件。
答案 0 :(得分:2)
目前,您正在创建两个单独的阵列。相反,从xml中提取一个数组,以便每个元素都有两个字段,然后通过Select-Object
将它们作为属性提取:
$xml = [xml](gc 'file.xml')
$table = $xml.cci_list.cci_items.cci_item |
Select @{N='CCI'; E={$_.id}}, @{N='Description'; E={$_.definition}}
$table | Export-Csv file.csv -NoTypeInformation