我正在尝试找到一个公式,该公式根据元素在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直接连接值,那会特别好,但是对于初学者来说,我很高兴知道我当前的方法出了什么问题。