Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/cplusplus/146.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
访问XML节点_Xml_Powershell - Fatal编程技术网

访问XML节点

访问XML节点,xml,powershell,Xml,Powershell,我正在从Web服务收集一些XML,收到的格式为: <devices> <device> <hostname>name</hostname> <SerialNumber>38xkf8</SerialNumber> <Uptime units="seconds">603835</Uptime> </device> <device> <

我正在从Web服务收集一些XML,收到的格式为:

<devices>
  <device>
    <hostname>name</hostname>
    <SerialNumber>38xkf8</SerialNumber>
    <Uptime units="seconds">603835</Uptime>
  </device>
  <device>
    <hostname>name</hostname>
    <SerialNumber>495dkf</SerialNumber>
    <Uptime units="seconds">92548</Uptime>
  </device>
</devices>
我无法仅获取返回的文本值

编辑:

解决方案:

Select-Xml -Xml $xml -XPath "//Device" | %
{
  $_.Node.Uptime.InnerText
}

格式良好的XML在引号之前需要等号

<Uptime units="seconds">603835</Uptime>

您还可以使用Select Xml执行此操作:

Select-Xml -Xml $xml -XPath "//Uptime" | ForEach{$_.Node.InnerText}
或者更简单地说,在旧版本的PowerShell中可能无法工作,我不确定:

(Select-Xml -Xml $xml -XPath "//Uptime").Node.InnerText

你犯了什么错误?你能显示你正在解析的实际XML以得到这个结果吗?我提出的剪报来自实际的XML文件。那么其他秒是从哪里来的,还是错误?您发布的代码片段是整个XML文件吗?就像一个备用单元会被称为属性一样,这是我写这个问题的错误。实际文件确实有“=”。这是完美的。非常感谢你!
(Select-Xml -Xml $xml -XPath "//Uptime").Node.InnerText