PowerShell:仅在结果中显示值而不是 @{}



我是PWSH的新手,对于你们来说,它看起来很容易,但我找不到按预期显示结果的方法。

$vm2 = Get-VM VM1234
$vmMemUsageAvg = get-VM $vm2.Name | Select @{N="Mem.Usage.Average";E={[Math]::Round((($_ |Get-Stat -Stat mem.usage.average -Start (Get-Date).AddHours(-24)-IntervalMins 5 -MaxSamples (12) |Measure-Object Value -Average).Average),2)}}

现在,例如,当请求$vmMemUsageAvg的结果时,我会收到此输出:

C:Windowssystem32> $vmMemUsageAvg 
Mem.Usage.Average
-----------------
              5.9

,但我只希望作为输出值,例如:5.9

将其放入

的Excel单元格中
$Sheet.Cells.Item($intRow, 13) = [String]$vmMemUsageAvg 

给我一个这样的字符串:

@{Mem.Usage.Average=5.9}

任何帮助欢迎仅显示此值

通过使用Select-Object @{N="Mem.Usage.Average";E={...}},您正在用属性Mem.Usage.Average制作一个对象,但看起来只是想要一个字符串。因此,只需取出Select

$vm2 = Get-VM VM1234
$vmMemUsageAvg = [Math]::Round(((get-VM $vm2.Name | Get-Stat -Stat mem.usage.average -Start (Get-Date).AddHours(-24)-IntervalMins 5 -MaxSamples (12) | Measure-Object Value -Average).Average),2)

相关内容

  • 没有找到相关文章

最新更新