如何在Powershell中使用等于命令的方法创建foreach循环

时间:2018-07-16 21:56:33

标签: arrays json powershell

我开始学习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
    }

}

任何指导将不胜感激。

1 个答案:

答案 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