Как прочитать или изменить JSON файл с помощью PowerShell?

Как прочитать или изменить JSON файл с помощью PowerShell?

JSON это популярный текстовый формат представления и передачи данных. В PowerShell есть два командлета для работы с форматом данных JSON: ConvertFrom-Json и ConvertTo-Json. В этой статье мы покажем, как создать, прочитать, или изменить JSON объекты и сохранить их в файлы с помощью PowerShell.

Данные в формате JSON представлены в виде пар
ключ
:
значение
(допускается вложение свойств) Допустим, вы хотите записать данные в формате JSON в файл. Создайте объект с данными:

$obj = @{
  "Name" = "Dmitriy",
    "Roles" = @{
        "AD" = "Admin",
        "SQL" = "Report"
    },
    "Company" = "winitpro"
}

Теперь этот объект нужно преобразовать в формат JSON и сохранить в файл с расширением .json:

$json = $obj | ConvertTo-Json
$json | Set-Content -Path C:PSuserroles.json

Теперь вы можете прочитать JSON файл:

$json = Get-Content -Path C:PSuserroles.json -Raw | ConvertFrom-Json

Вы можете вывести все свойства объекта JSON:

$json|fl

Или получить значение определенного свойства в объекте JSON:

$json.roles.sql

Чтобы добавить новое свойство в объект JSON, воспользуйтесь командой Add-Member:

$json| Add-Member -MemberType NoteProperty -Name "Email" -Value "[email protected]"

Прочитать JSON файл с помощью PowerShell

Чтобы изменить одно значение в объекте JSON и сохранить его в файл, воспользуйтесь такими командами:

$json.roles.sql='Report'
$json|ConvertTo-Json| Set-Content -Path C:PSuserroles.json

Удалить одно из свойств в JSON объекте:

$json.PSObject.Properties.Remove("Email")

С помощью PowerShell командлета Invoke-WebRequest можно прочитать данные JSON с любого веб сайта. Например, нам нужно найти A записи для определенного сайта, которые возвращает DNS служба Google в формате JSON:

$site="winitpro.ru"
$rawresp=Invoke-WebRequest "https://dns.google/resolve?name=$site&type=A"
$rawjson = ConvertFrom-Json -InputObject $rawresp.Content
$rawjson.answer.data

Обработка данных JSON в скрипте PowerShell

Qiziqarli malumotlar
Как прочитать или изменить JSON файл с помощью PowerShell?