我试图找到一个公式,根据它在 XML层次结构中的位置为元素创建一个URL. 这是我的示例xml: Xml Site Url="http://mysite.abc" Content/Content SubSites Site Url="/sub1" Content/Content SubSites Site Url="/sub2" Cont
这是我的示例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 | Select-XML -XPath "//ancestor::Site"
但是对于每个$Node,它选择所有’Site’元素.
它期望它在xml结构中找到更多的祖先.
如果有人知道如何将值直接与Xpath连接起来会特别好,但对于初学者来说,我很乐意知道我当前的方法出了什么问题.
// ancestor :: Site将为您提供相对于树中任何节点(//)的祖先Site节点.使用./ancestor :::Site只抓取相对于当前节点的祖先(.):
$Sites = $Node | Select-XML -XPath "./ancestor::Site"