微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Powershell:多个 Select-Object 语句仅返回第一个出现的结果

如何解决Powershell:多个 Select-Object 语句仅返回第一个出现的结果

我在 Windows 8.1 上运行 PowerShell 4.0 版

我有一个名为 flow1.xml 的 xml 文档(来自 nifi 流),如下所示:

<flowController encoding-version="1.3">
  <rootGroup>
    <id>123</id>
    <name>BigTime</name>
    <position x="0.0" y= "0.0"/>
    <processGroup>
      <id>456</id>
      <name>SmallTime</name>
      <position x="1000.0" y="2000.0"/>
      <processGroup>
        <id>789</id>
        <name>TinyTime</name>
        <position x="3000.0" y="4000.0"/>
      </processGroup>
    <processGroup/>
  </rootGroup>
</flowController>

我有一个 powerShell 脚本 test.ps1 如下:

$filePath='flow1.xml'
$xmlDocument = New-Object -TypeName XML
$xmlDocument.Load($filePath)

$xmlDocument.flowController.rootGroup.processGroup |
Where-Object { $_.name -eq 'SmallTime'} |
Select-Object -Property {$_.id}

$xmlDocument.flowController.rootGroup.processGroup.processGroup |
Where-Object { $_.name -eq 'TinyTime'} |
Select-Object -Property {$_.id}

我在 Windows Cmd 框中从 PowerShell 运行;即 PS C\Temp>test.ps 当我运行它时,我得到了预期的输出

Output:
$_.id
-----
456
789

当我改变第二个 Select_Object 时:

$xmlDocument.flowController.rootGroup.processGroup.processGroup |
Where-Object { $_.name -eq 'TinyTime'} |
Select-Object -Property {$_.name}

我明白

Output:
$_.id
-----
456

我只从第一个子句中得到 $_id,但没有从第二个子句中得到 $_name。一般情况是 - 如果两个 Select-Object 语句都选择相同的参数,则两者都将正确执行。例如,如果两个 Select-Object 语句都是 Select-Object -Property {$_.name} 我得到输出

Output:
$_.name
-----
SmallTime
TinyTime

如果 Select-Object 语句不同,它似乎只执行第一个。 我尝试在第二个选择对象之前再次读取 xmlDocument :

$filePath='flow1.xml'
$xmlDocument = New-Object -TypeName XML
$xmlDocument.Load($filePath)

$xmlDocument.flowController.rootGroup.processGroup |
Where-Object { $_.name -eq 'SmallTime'} |
Select-Object -Property {$_.id}

$xmlDocument = New-Object -TypeName XML
$xmlDocument.Load($filePath)
$xmlDocument.flowController.rootGroup.processGroup.processGroup |
Where-Object { $_.name -eq 'TinyTime'} |
Select-Object -Property {$_.id}

但同样的事情发生了。我只得到第一个 Select-Object 语句的结果。

有人知道为什么会这样吗?

解决方法

这听起来更像是一项家庭作业。下面的答案是这样处理的。换句话说,这些应该有助于指出一些问题,但这里的读者不应该为你做功课。

  • 请检查管道变量的正确格式。这是 $_ 不是 $
    例如,$_.Name Google:PowerShell 管道变量

  • 回顾比较运算符的使用。 PowerShell 中没有 .eq 之类的东西

  • 你的 XML 格式不正确,我不确定这个脚本是如何通过 $xmlDocument.Load() 用于加载文件的语法看起来不错,你在正确的轨道上加载属性值。一旦 XML 格式正确,您只需使用正确的数据路径即可。

  • 您只需一次读取 XML。

  • 您不需要在 select 语句中使用管道变量。只需属性名称就足够了。
    例如,Select-Object Name 这将返回 Name 属性的值

我希望这足以让你重新动起来。

,

只需添加此注释即可结束。

不知道管道出了什么问题。同事也遇到过类似的问题。所以我改变了策略。

我通过设置一个新变量深入到 $xmlDocument 中: $group = $xmlDocument.flowController.rootGroup.processGroup

并用适当的代码替换

foreach ($property in $group.property...){
   if ($property.name -eq 'oldValue'){
     parameter.value = 'newValue'
   }
}

这是有效的,并且可以通过更复杂的搜索进一步阐述/复杂化。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。