powershell psobject 嵌套有相同的引用。来自 json
powershell psobject nested with same reference. from json
我无法访问 psobject 的嵌套部分。
我用过
$response = Invoke-RestMethod
从应用程序中提取信息。
$response 然后包含一个 json 文件。
我已经清理了 json 文件,但这是通用格式。
Response:{
"total": 2,
"items": [
{
"id": 1,
"name": "127.0.0.1",
"properties": [
{
"name": "var1",
"value": "10"
},
{
"name": "var2",
"value": "20"
},
{
"name": "var3",
"value": "30"
},
{
"name": "var4",
"value": "40"
}
]
},
{
"id": 2,
"name": "10.2.2.2",
"properties": [
{
"name": "var1",
"value": "100"
},
{
"name": "var2",
"value": "200"
},
{
"name": "var3",
"value": "300"
},
{
"name": "var4",
"value": "400"
},
{
"name": "var5",
"value": "500"
}
]
},
],
"searchId": null,
"isMin": false
}
我可以使用简单的 for 循环直接在 items 层下轻松访问 id 和 name
for ( $index = 0; $index -lt $data.Items.count; $index++)
{
$id=$data.Items.id[$index]
$name=$data.Items.name[$index]
}
但我找不到如何引用属性部分下的内容。
这是我尝试过的一些东西
$var1 = Select-Object -ExpandProperty $data.Items.properties[$index]
$var1 = $data.Items.properties[$index] | Select-Object -expand name
$var1 = $data.Items.properties[$index] | Select -property *
其中一些比较接近,但只有 returns 一个名称条目,而不是全部。
在何处应用索引很重要。在你的最后应用索引
expression 在某些情况下有效,但并不像您期望的那样。
让我们仔细看看你到底在做什么:
$id = $data.Items.id[0]
$data.Items.id
returns 所有 "Items" 元素的所有 id 的数组:
PS> $data.Items.id
1
2
使用 $data.Items.id[0]
寻址该数组的第一个元素,即值
你要的那个。
现在将其与以下内容进行比较:
$id = $data.Items[0].id
$data.Items
returns 所有 "Items" 个元素的数组:
PS> $data.Items
id name properties
-- ---- ----------
1 127.0.0.1 {@{name=var1; value=10}, @{name=var2; value=20}, @{name=var3; value=30}, @{name=var4; value=40}}
2 10.2.2.2 {@{name=var1; value=100}, @{name=var2; value=200}, @{name=var3; value=300}, @{name=var4; value=400....}
使用 $data.Items[0]
寻址数组的第一个元素:
PS> $data.Items[0]
id name properties
-- ---- ----------
1 127.0.0.1 {@{name=var1; value=10}, @{name=var2; value=20}, @{name=var3; value=30}, @{name=var4; value=40}}
并且使用 $data.Items[0].id
可以寻址数组的第一个元素并且仅 select
它的内容是 id-属性.
一旦您拥有包含多个值的属性,在扩展其属性之前首先解决单个对象的好处就会很明显。比较以下输出:
PS> $data.Items.properties[0]
name value
---- -----
var1 10
PS> $data.Items[0].properties
name value
---- -----
var1 10
var2 20
var3 30
var4 40
正如您在评论中所说,您还想更改一个特定的值
属性。我建议您使用 Where-Object
缩小属性范围:
PS> $var2 = $data.Items[0].properties | Where-Object Name -eq 'var2'
PS> $var2.value = 25
PS> $data.Items[0].properties
name value
---- -----
var1 10
var2 25 <---
var3 30
var4 40
我无法访问 psobject 的嵌套部分。 我用过
$response = Invoke-RestMethod
从应用程序中提取信息。 $response 然后包含一个 json 文件。
我已经清理了 json 文件,但这是通用格式。
Response:{
"total": 2,
"items": [
{
"id": 1,
"name": "127.0.0.1",
"properties": [
{
"name": "var1",
"value": "10"
},
{
"name": "var2",
"value": "20"
},
{
"name": "var3",
"value": "30"
},
{
"name": "var4",
"value": "40"
}
]
},
{
"id": 2,
"name": "10.2.2.2",
"properties": [
{
"name": "var1",
"value": "100"
},
{
"name": "var2",
"value": "200"
},
{
"name": "var3",
"value": "300"
},
{
"name": "var4",
"value": "400"
},
{
"name": "var5",
"value": "500"
}
]
},
],
"searchId": null,
"isMin": false
}
我可以使用简单的 for 循环直接在 items 层下轻松访问 id 和 name
for ( $index = 0; $index -lt $data.Items.count; $index++)
{
$id=$data.Items.id[$index]
$name=$data.Items.name[$index]
}
但我找不到如何引用属性部分下的内容。
这是我尝试过的一些东西
$var1 = Select-Object -ExpandProperty $data.Items.properties[$index]
$var1 = $data.Items.properties[$index] | Select-Object -expand name
$var1 = $data.Items.properties[$index] | Select -property *
其中一些比较接近,但只有 returns 一个名称条目,而不是全部。
在何处应用索引很重要。在你的最后应用索引 expression 在某些情况下有效,但并不像您期望的那样。 让我们仔细看看你到底在做什么:
$id = $data.Items.id[0]
$data.Items.id
returns 所有 "Items" 元素的所有 id 的数组:
PS> $data.Items.id
1
2
使用 $data.Items.id[0]
寻址该数组的第一个元素,即值
你要的那个。
现在将其与以下内容进行比较:
$id = $data.Items[0].id
$data.Items
returns 所有 "Items" 个元素的数组:
PS> $data.Items
id name properties
-- ---- ----------
1 127.0.0.1 {@{name=var1; value=10}, @{name=var2; value=20}, @{name=var3; value=30}, @{name=var4; value=40}}
2 10.2.2.2 {@{name=var1; value=100}, @{name=var2; value=200}, @{name=var3; value=300}, @{name=var4; value=400....}
使用 $data.Items[0]
寻址数组的第一个元素:
PS> $data.Items[0]
id name properties
-- ---- ----------
1 127.0.0.1 {@{name=var1; value=10}, @{name=var2; value=20}, @{name=var3; value=30}, @{name=var4; value=40}}
并且使用 $data.Items[0].id
可以寻址数组的第一个元素并且仅 select
它的内容是 id-属性.
一旦您拥有包含多个值的属性,在扩展其属性之前首先解决单个对象的好处就会很明显。比较以下输出:
PS> $data.Items.properties[0]
name value
---- -----
var1 10
PS> $data.Items[0].properties
name value
---- -----
var1 10
var2 20
var3 30
var4 40
正如您在评论中所说,您还想更改一个特定的值
属性。我建议您使用 Where-Object
缩小属性范围:
PS> $var2 = $data.Items[0].properties | Where-Object Name -eq 'var2'
PS> $var2.value = 25
PS> $data.Items[0].properties
name value
---- -----
var1 10
var2 25 <---
var3 30
var4 40