Как прочитать или изменить 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:\PS\userroles.json

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

$json = Get-Content -Path C:\PS\userroles.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:\PS\userroles.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


Предыдущая статья Следующая статья


Комментариев: 0 Оставить комментарий

Оставить комментарий

Ваш e-mail не будет опубликован. Обязательные поля помечены *

Я не робот( Обязательно отметьте)