oys*_*oys 5 xml powershell 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直接连接值,那会特别好,但是对于初学者来说,我很高兴知道我当前的方法出了什么问题。
//ancestor::Site将为您提供Site相对于树中任何节点(//)的祖先节点。
用于./ancestor::Site仅获取相对于当前节点(.)的祖先:
$Sites = $Node | Select-XML -XPath "./ancestor::Site"
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1354 次 |
| 最近记录: |