Powershell 未在变量中存储每个循环信息



我正在尝试收集安装在一组服务器上的查看器列表。我正在尝试遍历该列表并运行 wmi 查询并存储结果并导出一个表,旁边有 wmi 结果和服务器名称。

我在服务器 2012 上运行它

$computers = Get-Content C:computers.txt
$WMIQuery = foreach ($computer in $computers){Get-WmiObject -Class 
Win32_Product | where-object {$_.name -match "Microsoft Viewer*"}}
$WMIQuery
$WMIQuery | Out-File c:Viewers.txt

期望的结果

服务器名称对象 1 对象 2

Server1 Microsoft Excel Viewer Microsoft Visio Viewer

我输出文件并得到一个空白的 txt 文件。

foreach ($computer in (Get-Content -Path "C:computers.txt")) {
    Get-WMIObject -ComputerName $computer -Class Win32_Product |
        Where-Object {$_.name -match "Microsoft Viewer" } |
            Out-File -Append -Path "C:viewers.txt"
}

您的原始代码无法识别要对其执行Get-WMIObject的计算机,因此它只查看运行脚本的计算机。

如果远程计算机上有许多

产品,则可能需要考虑在远程计算机上而不是本地进行筛选,以避免通过可能比理想速度慢的网络传输大量数据:

foreach ($computer in (Get-Content -Path "C:computers.txt")) {
    Get-WMIObject -ComputerName $computer -Class Win32_Product -Filter "Name LIKE '*Microsoft Viewer*'"|
        Out-File -Append -Path "C:viewers.txt"
}

(我想我的过滤器语法正确;我似乎每次编写新过滤器时都必须破解它......

我没有足够的代表来添加评论,但杰夫是对的。但是,原始海报的查询仍然存在问题。根据海报提供的示例,以下代码段不会产生任何结果:

{$_.name -match "Microsoft Viewer*"}

这需要更改为

{$_.name -like "*Microsoft*Viewer*"}

{$_.name -match "Microsoft.*?Viewer"}

最新更新