微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

xml – 选择祖先的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>

我在Powershell中有一个函数,从顶部和每个’Content’元素递归迭代我想要生成祖先Url值的串联.
因此它应该为每个“内容”节点连续生成

http://mysite.abc
http://mysite.abc/sub1
http://mysite.abc/sub1/sub2
http://mysite.abc/sub1/sub2/sub3

我现在用作开头:
($Node =’Content’元素)

$Sites = $Node | @R_717_3270@ -XPath  "//ancestor::Site"

但是对于每个$Node,它选择所有’Site’元素.
它期望它在xml结构中找到更多的祖先.

如果有人知道如何将值直接与Xpath连接起来会特别好,但对于初学者来说,我很乐意知道我当前的方法出了什么问题.

解决方法

// ancestor :: Site将为您提供相对于树中任何节点(//)的祖先Site节点.

使用./ancestor :::Site只抓取相对于当前节点的祖先(.):

$Sites = $Node | @R_717_3270@ -XPath  "./ancestor::Site"

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。