【问题标题】:powershell psobject nested with same reference. from jsonpowershell psobject 嵌套了相同的引用。来自 json
【发布时间】:2020-06-03 18:32:37
【问题描述】:

我在访问 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 *

其中一些接近,但只返回一个名称条目,而不是全部。

【问题讨论】:

  • 不太确定,您到底想看到什么。如果您想列出单个项目的所有名称条目,一个简单的$data.items[$index].properties 就可以了。
  • 您好,感谢收看。这导致了这个错误-+ $var1 = $data.Items.[$index].properties + ~ Missing type name after '['. 我希望能够例如在第一项中获取 var2 (20) 的值并将其分配给一个新的 var
  • 使用 $data.Items[$index].properties 代替 $data.Items.[$index].properties[$index] 之前有一个多余的点,不应该存在。

标签: json powershell psobject


【解决方案1】:

在哪里应用索引很重要。在你的最后应用索引 表达式在某些情况下有效,但并不完全符合您的预期。 让我们仔细看看你到底在做什么:

$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

正如您在 cmets 中所说,您还想更改一个特定的值 财产。我建议你使用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 

【讨论】:

  • 很棒的反应。正是我需要的,并提高了我的理解。完美回答。非常感谢。
猜你喜欢
  • 2020-04-18
  • 2021-10-25
  • 2016-03-21
  • 2021-02-11
  • 1970-01-01
  • 2017-10-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多