psobject powershell вложен с той же ссылкой. от json - PullRequest
0 голосов
/ 19 февраля 2020

Мне трудно получить доступ к вложенной части псобъекта. Я использовал

$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
}

Я могу легко получить доступ к идентификатору и имени непосредственно под слоем элементов, используя простой для l oop

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 *

Некоторые из них близки, но возвращают только одну из записей имени, а не все.

1 Ответ

0 голосов
/ 20 февраля 2020

Важно, где вы применяете индекс. Применение индекса в самом конце вашего выражения работает в некоторых случаях, но не совсем так, как вы ожидаете. Давайте подробнее рассмотрим, что именно вы делаете:

$id = $data.Items.id[0]

$data.Items.id возвращает массив всех идентификаторов всех элементов "Items":

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-свойства.

Преимущество обращения к одному объекту, прежде чем расширять его свойства, станет очевидным, как только вы получите свойства, которые содержат более одного значения. Сравните следующий вывод:

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 
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...