PowerShell创建嵌套的JSON

时间:2016-05-07 06:32:18

标签: json powershell

我正在尝试在PowerShell中创建一个JSON对象,以便我可以在python脚本中使用它。 我有混合的结果,我正在尝试将其压缩成一个命令,所以我可以从我的python脚本运行

ForEach ($disk in (Get-Partition).DiskNumber | select -Unique | Sort-Object)`
{ConvertTo-Json @{$disk.ToString()=`
ForEach ($part in (Get-Partition -DiskNumber $disk).PartitionNumber | Sort-Object)`
{@{$disk.ToString()=Get-Partition -DiskNumber $disk -PartitionNumber $part | `
ForEach-Object {ConvertTo-Json @{PartitionNumber=$_.PartitionNumber;DriveLetter=$_.DriveLetter;Offset=$_.Offset`
}}}}}}

这是我得到的输出:

{
    "0":  [
              {
                  "1":  "{\r\n    \"DriveLetter\":  null,\r\n    \"Offset\":  17408,\r\n    \"PartitionNumber\":  1\r\n}"
              },
              {
                  "2":  "{\r\n    \"DriveLetter\":  \"F\",\r\n    \"Offset\":  135266304,\r\n    \"PartitionNumber\":  2\r\n}"
              }
          ]
}
{
    "1":  [
              {
                  "1":  "{\r\n    \"DriveLetter\":  null,\r\n    \"Offset\":  1048576,\r\n    \"PartitionNumber\":  1\r\n}"
              },
              {
                  "2":  "{\r\n    \"DriveLetter\":  null,\r\n    \"Offset\":  315621376,\r\n    \"PartitionNumber\":  2\r\n}"
              },
              {
                  "3":  "{\r\n    \"DriveLetter\":  null,\r\n    \"Offset\":  419430400,\r\n    \"PartitionNumber\":  3\r\n}"
              },
              {
                  "4":  "{\r\n    \"DriveLetter\":  \"C\",\r\n    \"Offset\":  553648128,\r\n    \"PartitionNumber\":  4\r\n}"
              }
          ]
}
{
    "2":  [
              {
                  "1":  "{\r\n    \"DriveLetter\":  null,\r\n    \"Offset\":  17408,\r\n    \"PartitionNumber\":  1\r\n}"
              },
              {
                  "2":  "{\r\n    \"DriveLetter\":  \"D\",\r\n    \"Offset\":  135266304,\r\n    \"PartitionNumber\":  2\r\n}"
              }
          ]
}

问题是ConvertTo-Json在第一个键内创建一个列表/数组,并为该列表中的每个对象创建一个字典,有什么方法可以克服这个问题吗? 我可以删除的换行符,这不是一个大问题。 以下是我希望它的外观:

{
        "0":
            "1":  {"DriveLetter": null, "Offset": 17408, "PartitionNumber": 1},
            "2":  {"DriveLetter": "F", "Offset": 135266304, "PartitionNumber": 2}
    }
    {
        "1":
            "1":  {"DriveLetter": null, "Offset": 1048576, "PartitionNumber":  1},
            "2":  {"DriveLetter": null, "Offset": 315621376, "PartitionNumber":  2},
            "3":  {"DriveLetter": null, "Offset": 419430400, "PartitionNumber":  3},
            "4":  {"DriveLetter": "C", "Offset": 553648128, "PartitionNumber":  4}
    }
    {
        "2": 
            "1":  {"DriveLetter": null, "Offset": 17408, "PartitionNumber": 1},
            "2":  {"DriveLetter": "D", "Offset": 135266304, "PartitionNumber": 2}
    }

1 个答案:

答案 0 :(得分:4)

目前您的代码存在3个问题。

首先,你调用ConvertTo-Json(至少)两次 - 一次在内部分区哈希表上,然后再在外部哈希表上。

其次,您尚未指定Depth,这意味着内部词典将被折叠。

最后,如果您想要所描述的输出,则应使用分区号$part作为第二级词典的键:

foreach ($disk in (Get-Partition).DiskNumber | select -Unique | Sort-Object){
  ConvertTo-Json -Depth 3 @{
    "$disk" = foreach ($part in (Get-Partition -DiskNumber $disk).PartitionNumber | Sort-Object){
      @{
        "$part" = Get-Partition -DiskNumber $disk -PartitionNumber $part | ForEach-Object {
          @{
            PartitionNumber = $_.PartitionNumber;
            DriveLetter     = $_.DriveLetter;
            Offset          = $_.Offset
          }
        }
      }
    }
  }
}

以上将为n磁盘生成n离散JSON结构。

如果您想要将磁盘阵列作为根对象的单个结构,请将ConvertTo-Json移到整个表达式之外:

ConvertTo-Json -Depth 4 @(foreach ($disk in (Get-Partition).DiskNumber | select -Unique | Sort-Object){
  @{
    "$disk" = foreach ($part in (Get-Partition -DiskNumber $disk).PartitionNumber | Sort-Object){
      @{
        "$part" = Get-Partition -DiskNumber $disk -PartitionNumber $part | ForEach-Object {
          @{
            PartitionNumber = $_.PartitionNumber;
            DriveLetter     = $_.DriveLetter;
            Offset          = $_.Offset
          }
        }
      }
    }
  }
})