我开始学习PowerShell,并一直在尝试创建foreach循环,这样,如果其中一个JSON项的状态不是STARTED,那么它将使用其名称作为可执行命令中的变量来运行命令。这是我的json txt文件的样子;
{
"UNIT": {
"name": "AB",
"address": "fadasdaer",
"status": "MIA"
},
"UNIT": {
"name": "CD",
"address": "fadasdahsfaaer",
"status": "STARTED"
},
"UNIT": {
"name": "EF",
"address": "9afahegt",
"status": "DEAD"
}
}
我想做的是从json.txt
中读取此内容,并使其运行foreach循环并执行命令,该命令的名称已合并到命令中。我目前有这样的东西,但是我的PowerShell理解有限,并且不起作用...
$JSON = json.txt
$check = $JSON | ConvertFrom-Json
$started=STARTED
foreach($unit in $check.unit){
if ($unit.status -notmatch $started) {
$name=$unit.name
executable.exe start $name
}
}
任何指导将不胜感激。
答案 0 :(得分:6)
您的主要问题是您的JSON格式错误:它定义了一个单个对象,然后多次定义了其UNIT
属性{em> 。
您应将其定义为 array :请注意封闭的顶级[...]
和缺少UNIT
属性:
[
{
"name": "AB",
"address": "fadasdaer",
"status": "MIA"
},
{
"name": "CD",
"address": "fadasdahsfaaer",
"status": "STARTED"
},
{
"name": "EF",
"address": "9afahegt",
"status": "DEAD"
}
]
更正了JSON输入和其他语法问题:
$JSON = 'json.txt'
$check = Get-Content -Raw $JSON | ConvertFrom-Json
$started = 'STARTED'
foreach ($unit in $check) {
if ($unit.status -notmatch $started) {
$name = $unit.name
executable.exe start $name
}
}
如果您无法从源头修复JSON,则可以先进行转换,然后再将其传递给ConvertFrom-Json
:
$check = (Get-Content -Raw $JSON) `
-replace '\A\{', '[' `
-replace '\}\Z', ']' `
-replace '"UNIT": ' | ConvertFrom-JSON