![](/img/trans.png)
[英]Looping through properties inside a PSObject in PowerShell (from 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 *
其中一些接近,但只返回名稱條目之一而不是全部。
在何處應用索引很重要。 在某些情況下,在表達式的最后應用索引是可行的,但並不完全符合您的預期。 讓我們仔細看看你到底在做什么:
$id = $data.Items.id[0]
$data.Items.id
返回所有“Items”元素的所有 id 的數組:
PS> $data.Items.id
1
2
使用$data.Items.id[0]
可以尋址該數組的第一個元素,即您想要的值。
現在將其與以下內容進行比較:
$id = $data.Items[0].id
$data.Items
返回所有“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
處理數組的第一個元素並只選擇它的 id-property 的內容。
一旦您擁有包含多個值的屬性,在擴展其屬性之前首先尋址單個對象的好處將很明顯。 比較以下輸出:
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
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.