为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

如何存储Format-Table的输出以供以后使用我有一个脚本可以创建多个作业并在作业中存储两个简单的值。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          True192.168.0.101          False192.168.0.2            False192.168.0.251          True 
查看完整描述

1 回答

?
翻过高山走不出你

TA贡献1875条经验 获得超3个赞

Format-cmdlet问题

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

Microsoft.PowerShell.Commands.Internal.Format.FormatEndDataMicrosoft.PowerShell.Commands.Internal.Format.FormatEntryDataMicrosoft.PowerShell.Commands.Internal.Format.FormatStartDataMicrosoft.PowerShell.Commands.Internal.Format.GroupEndDataMicrosoft.PowerShell.Commands.Internal.Format.GroupStartData

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

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

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

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

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

这些,和其他,限制都可以用cmdlet的开关一样减轻-AutoSize-HideTableHeadersout-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

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

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


查看完整回答
反对 回复 2019-07-25
  • 1 回答
  • 0 关注
  • 574 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信