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

Web*_*ron 8 powershell

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

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

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

Get-Job | Receive-Job | sort RemoteAddress | FT
Run Code Online (Sandbox Code Playgroud)

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

$pcs = Get-Job | Receive-Job | sort RemoteAddress | FT
$pcs.RemoteAddress
Run Code Online (Sandbox Code Playgroud)

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

Get-Job | Receive-Job | sort RemoteAddress | FT
Run Code Online (Sandbox Code Playgroud)

输出:

RemoteAddress PingSucceeded                        
------------- -------------                         
192.168.0.163          True
192.168.0.101          False
192.168.0.2            False
192.168.0.251          True 
Run Code Online (Sandbox Code Playgroud)

Mat*_*att 15

Format-cmdlet问题

这里的问题是你使用的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
Run Code Online (Sandbox Code Playgroud)

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

Get-ChildItem c:\temp | Format-Table | Get-Member
Run Code Online (Sandbox Code Playgroud)

所以,你不再有System.IO.FileInfoSystem.IO.DirectoryInfo,你通常会从得到的对象Get-ChildItem

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

Ten Numbers                                                                                                                                                  
-----------                                                                                                                                                  
{1, 2, 3, 4...}  
Run Code Online (Sandbox Code Playgroud)

这些,和其他,限制都可以用cmdlet的开关一样减轻-AutoSize-HideTableHeaders,out-string -width等等.这不然而,由于事...


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

  • 将结果保存在变量中?:$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

  • 使用所述属性执行内联计算?:使用计算表达式,就像使用Format-Cmdlet一样.$result | Select prop1, @{Name="prop2";Expression={$_.prop2 * 3}

潜在的可接受用途

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

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

$body = Get-ChildItem c:\temp | Format-Table | Out-String
Run Code Online (Sandbox Code Playgroud)

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

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