-3

我在 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 语句不同,它似乎只执行第一个语句。我尝试在第二个 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 语句的结果。

有谁知道为什么会这样?

4

2 回答 2

0

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

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

  • 查看比较运算符的使用。PowerShell 中没有 .eq 这样的东西

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

  • 您只需要一次读取 XML。

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

我希望这足以让你再次动起来。

于 2021-04-14T20:08:48.337 回答
0

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

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

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

并用适当的替换代码

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

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

于 2021-05-10T14:48:04.617 回答