我需要以与 PowerShell 相同的方式将 PowerShell PSObject 转换为流。PowerShell 还以通用方式提供标准流的输出。
例如$PSVersionTable
,仅输出 2 列(名称、值)而不是整个哈希表。因此,我希望每个 PSObject 都以与 PowerShell 在后台执行的方式相同的标准方式进行处理。此外,我想将其转换为 DataTable。我知道,还有其他链接说明了这个问题,但它们正在对 PSObject 的所有属性进行操作。不知何故,PowerShell 开箱即用。
我需要将 PSObject 转换为其他类型吗?
例子
PowerShell 脚本输出$PSVersionTable
为
PS版本 5.1.17134.228 PSEdition 桌面版 PSCompatibleVersions {1.0、2.0、3.0、4.0...}
$host
或Get-Host
输出为
Get-WebApplication
输出
名称 应用程序池 协议 物理路径 ---- ---- --------- ------------- IisHostedServer DefaultAppPool http C:\TestDirectory\Src\IisHostedServer
Get-ChildItem -Path "C:\TestDirectory\TestSubDir\Studio"
:
模式 LastWriteTime 长度 名称 ---- ------------- ------ ---- d----- 29.06.2018 11:54 TestFileDir d----- 24.07.2018 16:37 测试站点 -a---- 13.08.2018 11:53 343 TestXml.xml
同样,可能还有其他引用或自定义类型。
我想在 C# 中以相同的方式获取这些输出,并且需要将它们显示为 String 或 DataTable。是否有任何从 PSObject 到流的转换或以完全通用的方式返回以上输出的东西?
当我在 C# 中处理以下方法时:
var outputCollection = new PSDataCollection<PSObject>();
outputCollection.DataAdded += OnOutputDataAdded;
powerShell.Invoke(null, outputCollection);
private void OnOutputDataAdded(object sender, DataAddedEventArgs e)
{
var records = (PSDataCollection<PSObject>) sender;
var data = records[e.Index];
var outputTable = ConverToLogableDataStream(data);
}
private void ConverToLogableDataStream(PSObject)
{
...
...
}