点符号不返回任何结果

时间:2013-07-18 23:00:07

标签: xml powershell

我正在尝试使用点表示法来查找此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>

有没有理由我找不到网页元素?是因为有多个网站元素或其他原因?

1 个答案:

答案 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 }