我正在尝试使用点表示法来查找此XML中的Web元素列表:
<Databases>
<Database SiteCount="2" Name="MyDB" DataSource="BLAHDEV">
<Site Id="72affdff-b0a9-404e-a000-08cfc1c2828a" OwnerLogin="Blah\Blah" InSiteMap="True">
<Webs Count="1">
<Web Id="5fb7df63-0ab3-4cb2-88de-1a94ceda0fbf" Url="/people/me/blah" LanguageId="1033" TemplateName="SPSPERS#0" TemplateId="21" />
</Webs>
</Site>
<Site Id="9ae7dd88-cdd9-4d22-b6af-2185ddb22994" OwnerLogin="Blah\Blah" InSiteMap="True">
<Webs Count="1">
<Web Id="45d2d002-4e7d-4f22-9cd2-c93fdd49daab" Url="/people/me/blah2" LanguageId="1033" TemplateName="SPSPERS#0" TemplateId="21" />
</Webs>
</Site>
</Database>
</Databases>
然后我将它加载到powershell:
[xml]$xml = Get-Content MyXMLFile.xml
使用点表示法查询直到Site元素:
PS> $xml
Databases
---------
Databases
PS> $xml.Databases
Database
--------
Database
PS> $xml.Databases.Database
SiteCount Name DataSource Site
--------- ---- ---------- ----
2 MyDB BLAHDEV {Site, Site}
PS> $xml.Databases.Database.Site
Id OwnerLogin InSiteMap Webs
-- ---------- --------- ----
72affdff-b0a9-404e-a000-08... Blah\Blah True Webs
9ae7dd88-cdd9-4d22-b6af-21... Blah\Blah True Webs
但是,当我尝试获取Webs元素时,不会返回任何结果:
PS> $xml.Databases.Database.Site.Webs
PS>
有没有理由我找不到网页元素?是因为有多个网站元素或其他原因?
答案 0 :(得分:4)
$xml.Databases.Database.Site
是一个集合,你需要管道它:
$xml.Databases.Database.Site | Select -Expand Webs
或者使用xpath(编辑:SelectNodes用于每个元素,而不是集合)
...Site | ForEach { $_.SelectNodes('Webs') } #or something similar
或循环
...Site | ForEach { $_.Webs }