Sun*_*ile 2 xml powershell xpath xmldocument xmlnode
我有这个 PowerShell 脚本,用于解析 XML 文件的不同方面。因此,我想检索特定 XML 节点的值并将其保存到变量中。我想要选择的这个节点在 XML 文件中存在多次,因此我需要能够提及我想要检索的节点的具体编号。
XML 文件:
<lvl1>
<lvl2>
<lvl3>
<lvl4>test1</lvl4>
<lvl4>test2</lvl4>
<lvl4>test3</lvl4>
</lvl3>
</lvl2>
</lvl1>
Run Code Online (Sandbox Code Playgroud)
我尝试过的Powershell脚本:
[xml] $response = get-content "FilePath\Resp.xml"
[string] $Var = $response.SelectSingleNode('lvl1/lvl2/lvl3/lvl4[2]').InnerText
Run Code Online (Sandbox Code Playgroud)
[xml] $response = get-content "FilePath\Resp.xml"
$Var = $response.lvl1.lvl2.lvl3.lvl4[2].'#text'
Run Code Online (Sandbox Code Playgroud)
培根在对这个问题的评论中基本上提供了关键的指示:
使用PowerShell的点表示法直接返回叶子元素(只有文本子节点的元素)的文本内容,因此不需要'.#text':
# Note: `.lvl4` is an *array* provided by PowerShell, so the index is
# 0-based. Therefore, [2] retrieves the *3rd* element.
$response.lvl1.lvl2.lvl3.lvl4[2] # -> 'test3'
Run Code Online (Sandbox Code Playgroud)
请注意,PowerShell 将多个lvl4元素公开为数组,因此对该数组的索引是0基于的。
您的基于XPath的命令应该按原样工作,但请注意XPath 中的索引是1基于 - 的,因此[2]将引用第二个元素:
$response.SelectSingleNode('lvl1/lvl2/lvl3/lvl4[2]').InnerText # -> 'test2'
# Equivalent commands:
$response.SelectSingleNode('lvl1/lvl2/lvl3/lvl4[2]').'#text'
$response.SelectSingleNode('lvl1/lvl2/lvl3/lvl4[2]/text()').Value
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
13723 次 |
| 最近记录: |