我正在尝试在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}
}
答案 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
}
}
}
}
}
})