Powershell:按元素索引将 XML 节点值选择到变量中

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脚本:

1 不返回任何内容并且没有错误

[xml] $response = get-content "FilePath\Resp.xml"
[string] $Var = $response.SelectSingleNode('lvl1/lvl2/lvl3/lvl4[2]').InnerText
Run Code Online (Sandbox Code Playgroud)

2 返回错误:“无法索引到空数组。”

[xml] $response = get-content "FilePath\Resp.xml"
$Var = $response.lvl1.lvl2.lvl3.lvl4[2].'#text'
Run Code Online (Sandbox Code Playgroud)

mkl*_*nt0 5

培根在对这个问题的评论中基本上提供了关键的指示:

使用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)