看起来Powershell在导出到JSON时会切断数据,如果它太深了。我的对象hierchy看起来像这样:
Main Object
Metadata
More Metadata
Collection of Other object Sources
Collection of data used by these sources
出于某种原因,当我转换为JSON时,powershell将第三级(这些源使用的数据集合)导出为空字符串,即使它是添加了各种NoteProperties的对象数组。例如:
$test = New-Object -TypeName PSObject
$obj = New-Object -TypeName PSObject
$obj | Add-Member -MemberType NoteProperty -Name "Name" -Value "adsf"
$test2 = New-Object -TypeName PSObject
$test2 | Add-Member -MemberType NoteProperty -Name "ArrayTest" -Value @($obj, $obj)
$test3 = New-Object -TypeName PSObject
$test3 | Add-Member -MemberType NoteProperty -Name "ArrayTest" -Value @($obj, $obj, $obj)
$test | Add-Member -MemberType NoteProperty -Name "CollectionTest" -Value @($test2, $test3)
这会产生以下JSON字符串:
PS C:\Users\user\projects\Powershell> $test | ConvertTo-Json
{
"CollectionTest": [
{
"ArrayTest": " "
},
{
"ArrayTest": " "
}
]
}
转换为XML会导致类似情况:
<?xml version="1.0"?>
<Objects>
<Object Type="System.Management.Automation.PSCustomObject">
<Property Name="CollectionTest" Type="System.Object[]">
<Property Type="System.Management.Automation.PSCustomObject">
<Property Type="System.String">@{ArrayTest=System.Object[]}</Property>
<Property Name="ArrayTest" Type="System.Management.Automation.PSNoteProperty">System.Object[]</Property>
</Property>
<Property Type="System.Management.Automation.PSCustomObject">
<Property Type="System.String">@{ArrayTest=System.Object[]}</Property>
<Property Name="ArrayTest" Type="System.Management.Automation.PSNoteProperty">System.Object[]</Property>
</Property>
</Property>
</Object>
</Objects>
PowerShell中是否存在某种对象嵌套限制?
答案 0 :(得分:29)
来自Get-Help ConvertTo-JSON:
-Depth&lt; Int32&gt;
指定JSON表示中包含的包含对象的级别数。默认值为2.
将-Depth参数设置为保存数据所需的任何深度。