如何存储Format-Table的输出以供以后使用

问题描述 投票:4回答:1

我有一个脚本可以创建多个作业并在作业中存储两个简单的值。

Start-Job -ScriptBlock {param ([string]$compip) tnc $compip | select RemoteAddress,PingSucceeded -WarningAction SilentlyContinue} -ArgumentList $compip

这很好用。我想知道的是如何将以下代码存储到变量中?

Get-Job | Receive-Job | sort RemoteAddress | FT

我试过这个,但它没有像我想的那样工作:

$pcs = Get-Job | Receive-Job | sort RemoteAddress | FT
$pcs.RemoteAddress

我是以错误的方式去做的吗?我想存储上面的get-job命令中的数据,以便稍后在脚本中使用这些值。我认为它会工作,因为输出看起来正确:命令:

Get-Job | Receive-Job | sort RemoteAddress | FT

输出:

RemoteAddress PingSucceeded                        
------------- -------------                         
192.168.0.163          True
192.168.0.101          False
192.168.0.2            False
192.168.0.251          True 
powershell
1个回答
11
投票

Problem with Format-cmdlets

这里的问题是你使用FT,这是Format-Table的别名。这些Format- cmdlet仅适用于控制台/屏幕输出。你可以用很多东西来定制输出,但在每种情况下,PowerShell都需要按摩数据才能这样做。这包括将传递的对象分解为不同对象的组...

Microsoft.PowerShell.Commands.Internal.Format.FormatEndData
Microsoft.PowerShell.Commands.Internal.Format.FormatEntryData
Microsoft.PowerShell.Commands.Internal.Format.FormatStartData
Microsoft.PowerShell.Commands.Internal.Format.GroupEndData
Microsoft.PowerShell.Commands.Internal.Format.GroupStartData

上述数据类型是从运行此代码中提取的。

Get-ChildItem c:\temp | Format-Table | Get-Member

所以你不再拥有通常从System.IO.FileInfo获得的System.IO.DirectoryInfoGet-ChildItem物体

另一个大问题来自Format-cmdlets本质到截断数据,比如具有大量元素或长字符串的数组,以便在屏幕上尽可能多地适应。在数组的情况下,这是由于偏好变量$FormatEnumerationLimit,它通常默认为4。

Ten Numbers                                                                                                                                                  
-----------                                                                                                                                                  
{1, 2, 3, 4...}  

使用像-AutoSize-HideTableHeadersout-string -width等cmdlet开关可以减轻这些和其他限制。但这并不重要因为...


Solution

好消息是解决方案非常简单。停止将它们用于除控制台输出之外的任何其他使用我之前的例子:

  • 将结果保存在变量中?:$result = Get-ChildItem C:\temp
  • 出口数据:Get-ChildItem C:\temp | Export-CSV $path -NoTypeInformation。其他Export-cmdlet在这里可能更喜欢Export-CLIXml用于复杂对象,当你想将它们存储在别处使用时。如果您只是想要在输出中包含一些非常好的东西,那么请考虑使用ConvertTo-HTML
  • 提取个别属性?:只需使用Select-Object$result | Select prop1, prop2。您还可以扩展属性选择以使用-ExpandProperty获取字符串或字符串数​​组:$result | Select -ExpandProperty prop1
  • 使用所述属性执行内联计算?:Use calculated expression就像使用Format-Cmdlet一样。 $result | Select prop1, @{Name="prop2";Expression={$_.prop2 * 3}

潜在的可接受用途

有些人更喜欢输出用于电子邮件和记录统计信息。虽然将数据保存在更易于使用的格式中以供以后使用是不可或缺的。但是,如果您真的需要这些数据,请记住您不再使用原来的对象了。

因此,如果您需要表格格式的数据但存储为字符串,请考虑Out-String

$body = Get-ChildItem c:\temp | Format-Table | Out-String

但请记住,Format-Table将播放对象输出,以使其显示在屏幕上(截断的数组属性和长字符串)。真的..如果你想要它很好和格式化,那么你应该只使用ConvertTo-HTML

要点几乎不需要保存Format-Table中的数据。几乎总有一种更好的方法。

© www.soinside.com 2019 - 2024. All rights reserved.