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

时间:2016-04-01 13:48:34

标签: powershell

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

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 

1 个答案:

答案 0 :(得分:10)

Format-cmdlets

的问题

此处的问题是您使用的FTFormat-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切换可以减轻这些限制和其他限制。但这并不重要因为......

解决方案

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

  • 将结果保存在变量中?$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中的数据。几乎总有一种更好的方法。