如何解决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 举报,一经查实,本站将立刻删除。