小编oys*_*oys的帖子

Xpath选择祖先

我正在尝试找到一个公式,该公式根据元素在XML层次结构中的位置为该元素创建URL。

这是我的示例xml:

<Xml>
    <Site Url="http://mysite.abc">
        <Content></Content>
        <SubSites>
            <Site Url="/sub1">
                <Content></Content>
                <SubSites>
                    <Site Url="/sub2">
                        <Content></Content>
                        <SubSites>
                            <Site Url="/sub3">
                                <Content></Content>
                            </Site>
                        </SubSites>
                    </Site>
                </SubSites>
            </Site>
        </SubSites>
    </Site>
</Xml>
Run Code Online (Sandbox Code Playgroud)

我在Powershell中有一个函数,该函数从顶部开始递归地向下迭代,并在每个我要生成祖先Url值的“内容”元素上进行迭代。因此,它应该为每个“内容”节点连续生成:

http://mysite.abc
http://mysite.abc/sub1
http://mysite.abc/sub1/sub2
http://mysite.abc/sub1/sub2/sub3
Run Code Online (Sandbox Code Playgroud)

我现在使用它作为开始:($ Node ='Content'元素)

$Sites = $Node | Select-XML -XPath  "//ancestor::Site"
Run Code Online (Sandbox Code Playgroud)

但是,对于每个$ Node,它都会选择所有“ Site”元素。希望它在xml结构下降时能找到更多的祖先。

如果有人会知道如何使用Xpath直接连接值,那会特别好,但是对于初学者来说,我很高兴知道我当前的方法出了什么问题。

xml powershell xpath

5
推荐指数
1
解决办法
1354
查看次数

标签 统计

powershell ×1

xml ×1

xpath ×1