Powershell 如何存储格式表的输出以供以后使用

Powershell 如何存储格式表的输出以供以后使用,powershell,Powershell,我有一个脚本,可以创建几个作业,并在作业中存储两个简单的值 Start-Job -ScriptBlock {param ([string]$compip) tnc $compip | select RemoteAddress,PingSucceeded -WarningAction SilentlyContinue} -ArgumentList $compip 这个很好用。我想知道的是如何将以下代码存储到变量中 Get-Job | Receive-Job | sort RemoteAddres

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

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
命令中的数据,以便稍后在脚本中使用这些值。我认为它会工作,因为输出看起来是正确的: 命令:

输出:

RemoteAddress PingSucceeded                        
------------- -------------                         
192.168.0.163          True
192.168.0.101          False
192.168.0.2            False
192.168.0.251          True 
格式化cmdlet存在问题 这里的问题是如何使用
FT
,它是
格式表
的别名。这些
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
因此,您不再拥有通常从
get ChildItem
获取的
System.IO.FileInfo
System.IO.DirectoryInfo
对象

另一个大问题来自于格式化cmdlet的性质,即截断数据,如包含大量元素或长字符串的数组,以尽可能适合屏幕。在数组的情况下,这是由于preference变量导致的,该变量通常默认为4

Ten Numbers                                                                                                                                                  
-----------                                                                                                                                                  
{1, 2, 3, 4...}  
使用cmdlet开关,如
-AutoSize
-HideTableHeaders
out string-width
等,可以减轻这些限制和其他限制。但这并不重要,因为


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

  • 将结果保存到变量中?
    $result=Get ChildItem C:\temp

  • 导出数据
    获取子项C:\temp |导出CSV$path-NoTypeInformation
    。其他
    Export-
    cmdlet在这里可能是首选的,就像对于复杂对象一样,当您希望存储它们以供其他地方使用时。如果您只是在输出中查找一些很好的东西,那么请考虑<代码>转换为HTML<代码>。
  • 提取单个属性?:只需使用
    选择对象
    <代码>$result |选择prop1、prop2。您还可以使用
    -ExpandProperty
    $result | Select-ExpandProperty prop1

  • 使用所述属性执行内联计算?:就像使用Format cmdlet一样<代码>$result |选择prop1,@{Name=“prop2”;表达式={$\.prop2*3}


潜在可接受用途

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

因此,如果您需要以表格格式存储数据,但应将其存储为字符串,则考虑<代码>输出字符串< /代码>

$body = Get-ChildItem c:\temp | Format-Table | Out-String
但是请记住,
Format Table
将处理对象输出,以使其显示在屏幕上(截断的数组属性和长字符串)。真的。如果您希望它美观且格式化,那么您应该使用
ConvertTo HTML

关键是您几乎不需要从Format表中保留数据。几乎总是有更好的方法。

Format cmdlet存在问题 这里的问题是您对
FT
的使用,它是
格式表
的别名。这些
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
因此,您不再拥有通常从
get ChildItem
获取的
System.IO.FileInfo
System.IO.DirectoryInfo
对象

另一个大问题来自Format cmdlet对截断数据(如包含大量元素或长字符串的数组)的性质,以尽可能适合屏幕。对于数组,这是由于首选项变量(通常默认为4)造成的

Ten Numbers                                                                                                                                                  
-----------                                                                                                                                                  
{1, 2, 3, 4...}  
使用cmdlet开关,如
-AutoSize
-HideTableHeaders
out string-width
等,可以减轻这些限制和其他限制。但这并不重要,因为


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

  • 将结果保存到变量中?
    $result=Get ChildItem C:\temp

  • < > > >强>导出数据<强> >:获取子项目C:\Timp导出CSV $PATH NOTYPE信息< /代码>。ML

  • 提取单个属性?:只需使用
    选择对象
    $result |选择prop1、prop2
    。您还可以扩展属性选择,只需使用
    -ExpandProperty
    $result |选择-ExpandProperty prop1

  • 使用所述属性执行内联计算?:就像使用Format cmdlet一样。
    $res