使用PowerShell处理JSON字符串

时间:2015-01-14 01:06:09

标签: json powershell

假设我在PowerShell字符串中有一段JSON,例如

$s = '{"foo":"hello"}'

我的目标是将其转换为可以操作的对象(例如,更改/添加属性),然后转换回json字符串。

所以试着明白了,我写道:

$o = $s | ConvertFrom-Json    # convert the json string to an object
$o.foo = "hello2"             # change an existing prop
$o.bar = "World"              # add a new prop
$s2 = $o | ConvertTo-Json     # convert back into a json string

问题是我从ConvertFrom-Json返回的对象是PSCustomObject类型,它不允许添加属性。所以第三行爆发了:

Exception setting "bar": "The property 'bar' cannot be found on this object. Verify that the property exists and can be set." At line:1 char:1

问题:在不带太多复杂性的情况下,最好的方法是什么?

1 个答案:

答案 0 :(得分:8)

自定义对象执行允许您添加属性,您只需正确执行即可。您需要Add-Member cmdlet。

$o = $s | ConvertFrom-Json    # convert the json string to an object
$o.foo = "hello2"             # change an existing prop
Add-Member -InputObject $o -MemberType NoteProperty -Name 'bar' -Value "World"              # add a new prop
$s2 = $o | ConvertTo-Json     # convert back into a json string

值得注意的是,根据您的PowerShell版本,Add-Member行可以简化为:

$o | Add-Member 'bar' 'World'

我不确定哪种语法可以接受,但我知道它在第4版中有效,我认为它适用于v3。