将1维字符串数组转换为json文件

问题描述 投票:1回答:1

也许这是一个简单的问题,将被禁止,但我今天花了几个小时,而不是像我预期的那样让它工作。所以我有这样的对象:

data_1 data_2 ... abra_12 ...

我想把它转换成json像这样:

[
    {"data_1" : "data_1"},
    {"data_2" : "data_2"},
    ...
]

我试过这个:

$result = Get-ChildItem $Path2Search -recurse | Select-String -Pattern '(?<=locI(.*)\(\").+?(?=\")' -casesensitive | foreach {$_.matches} | select value | ConvertTo-Json | Out-File $save2file

但是我得到了这个:

{
   "Value":  "data_1"
},
{
   "Value":  "data_2"
},

虽然我想这样:

{
   "data_1":  "data_1"
},
{
   "data_2":  "data_2"
},

有什么建议吗? :)

arrays json powershell
1个回答
3
投票

您可以先在键值列表中对结果进行整形,然后将其转换为json。

例如,如果输入是逗号分隔的字符串,则可以使用:

$input = "data_1, data_2, data_3"
$input.Split(',').Trim() | 
    ForEach-Object {@{$_=$_}} | 
        ConvertTo-Json | 
             Out-File "C:\test.txt"

或者,如果输入是字符串数组:

$input = @("data_1", "data_2", "data_3")
$input | ForEach-Object {@{$_=$_}} | 
        ConvertTo-Json |
            Out-File "C:\test.txt"

结果将是:

[
    {
        "data_1":  "data_1"
    },
    {
        "data_2":  "data_2"
    },
    {
        "data_3":  "data_3"
    }
]

虽然我更喜欢使用上面的解决方案来创建json结果,但你也可以依赖字符串操作:

$input = "data_1, data_2, data_3"
@"
[ 
`t$(($input -split '\s*,\s*' |%{"{ `"$_`" : `"$_`" }"}) -join ",`n`t")
]
"@
© www.soinside.com 2019 - 2024. All rights reserved.