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
cmdlet在这里可能是首选的,就像对于复杂对象一样,当您希望存储它们以供其他地方使用时。如果您只是在输出中查找一些很好的东西,那么请考虑<代码>转换为HTML<代码>。Export-
- 提取单个属性?:只需使用
<代码>$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