[英]PowerShell convert string to json
在 PowerShell 中,我有以下字符串,我从文件中读取并需要转换为 json:
"@{Account='User01';Domain='Domain01';Admin='True'}"
您可以尝试一些字符串操作以获得预期的JSON格式,然后使用ConvertFrom-Json
将其转换为PSCustomObject 。
简单示例:(简单,因为这假设被替换的这些字符只是分隔符)
# First, clean up the string.
PS C:\> $mystring = "@{Account='User01';Domain='Domain01';Admin='True'}"
PS C:\> $mystring = $mystring -replace "^@", ""
PS C:\> $mystring = $mystring -replace "=", ":"
PS C:\> $mystring = $mystring -replace ";", ","
PS C:\> $mystring
{Account:'User01',Domain:'Domain01',Admin:'True'}
# Afterwards, convert to PSCustomObject.
PS C:\> $myobject = $mystring | ConvertFrom-Json
PS C:\> $myobject
Account Domain Admin
------- ------ -----
User01 Domain01 True
这也可以转换回JSON:
PS C:\> $myobject | ConvertTo-Json
{
"Account": "User01",
"Domain": "Domain01",
"Admin": "True"
}
以上适用于深度最多为 2 的 Json 或 PS 对象。如果您的对象包含嵌套对象,则需要指定
-Depth<\/code>参数。
PS C:\> $json=
'{
"level1":[
{
"attr1":"value1",
"level2":[
{
"attr2.1":"value2.1",
"attr2.2":"value2.2"
}
]
}
],
"Comment":"3-level object"
}'
PS C:\> $psobj = ConvertFrom-Json $json
PS C:\> $psobj
level1 Comment
------ -------
{@{attr1=value1; level2=System.Object[]}} 3-level object
PS C:\> Convertto-Json $psobj
{
"level1": [
{
"attr1": "value1",
"level2": ""
}
],
"Comment": "3-level object"
}
PS C:\> Convertto-Json $psobj -Depth 3
{
"level1": [
{
"attr1": "value1",
"level2": [
"@{attr2.1=value2.1; attr2.2=value2.2}"
]
}
],
"Comment": "3-level object"
}
PS C:\> Convertto-Json $psobj -Depth 4
{
"level1": [
{
"attr1": "value1",
"level2": [
{
"attr2.1": "value2.1",
"attr2.2": "value2.2"
}
]
}
],
"Comment": "3-level object"
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.