我正在使用 PowerShell 4.0 中的 New-WebServiceProxy 从 API 中提取数据,然后将其传送到 JSON 文件以供审查并导入另一个 API 服务(相同的 API 版本等,只是不同的主机)。
$tasklist.Taskconfig | ConvertTo-JSON-Depth 50 -As String | Out-File -FilePath $exportpath\$name.xml -Force
给我包含 TaskConfig 的 XML。在这种情况下,TaskConfig 是我正在与之交互的 API 自动生成的对象类型。当我想导入我正在使用的内容时:
$taskconfig = (Get-Content "$taskjson") -join "`n" | ConvertFrom-Json
但是当我运行它时,它无法创建对象。我认为这是因为 JSON 包含嵌套的子级,导致错误-
无法将值“@{Name=plugindive;Value=;> Children=System.Object[]}”转换为类型“Microsoft.PowerShell.Commands.NewWebserviceProxy.AutogeneratedTypes.WebServiceProxy1rcleWeb_WebClientAPI_asmx_wsdl.TaskConfig”。错误:“无法转换”@{Name=plugindive; Value=;Children=System.Object[]}” 类型“System.Management.Automation.PSCustomObject”的值以键入“Microsoft.PowerShell.Commands.NewWebserviceProxy.AutogeneratedTypes.WebServiceProxy1rcleWeb_WebClientAPI_asmx_wsdl.TaskConfig”。
我试过明确说明对象的类型:
$taskconfig = [Microsoft.PowerShell.Commands.NewWebserviceProxy.AutogeneratedTypes.WebServiceProxy1rcleWeb_WebClientAPI_asmx_wsdl.TaskConfig](Get-Content "$taskjson" | Out-string | ConvertFrom-Json)
以及创建对象然后尝试从我的 JSON 添加孩子 -
$taskconfig.children = $json.children
但这些都以同样的方式失败。
有趣的是,我似乎在 PowerShell 5.0 中没有遇到同样的问题,但我无法验证原因——还有其他方法可以解决这个问题吗?
在下面添加了示例 JSON
{"Name": "plugindive",
"Value": null,
"Children": [{
"Name": "auto",
"Value": "False",
"Children": [
]
},
{
"Name": "categories",
"Value": null,
"Children": [{
"Name": "Module Z",
"Value": "False",
"Children": [
]
},
{
"Name": "Module A",
"Value": "False",
"Children": [
]
},
{
"Name": "Module B",
"Value": "False",
"Children": [
]
},
{
"Name": "Module C",
"Value": "False",
"Children": [
]
}
]
}
]
}