在if中,PowerShell的语法是这样的:
if (<test1>)
{<statement list 1>}
[elseif (<test2>)
{<statement list 2>}]
[else
{<statement list 3>}]另一个语法规则是,对于子表达式,需要使用括号,如下所示:
write-output (get-date)因此,结合这两条规则,我希望对某些路径的测试需要用两组括号来编写,如下所示:
if ((Test-Path ...)) {
# do something
}然而,这也适用于:
if (Test-Path ...) {
# do something
}为了完整起见,这个不工作:
if (!Test-Path ...) {
# do something
}(在这里,您需要像往常一样将子表达式括在括号中)。
有人能解释一下这里应用的语法规则吗?为什么我只能用一个括号来使用IF测试?是PowerShell的魔力,还是我误解了基本的语法规则?
发布于 2012-06-17 21:21:39
参考附录C:在Bruce的Windows PowerShell在运行中中的C.2.2,我们有:
<ifStatementRule> =
'if' '(' <pipelineRule> ')' <statementBlockRule>
[ 'elseif' '(' <pipelineRule> ')' <statementBlockRule> ]*
[ 'else' <statementBlockRule> ]{0|1}这表明(和)令牌是识别if语句的字面语法的一部分,而about_If文档中的<test>引用了将解析为布尔值的管道。
根据管道规则,我们发现:
Test-Path ...解析为<cmdletCall> of <name> <parameterArgumentToken>,!Test-Path ...导致<expressionRule> of <UnaryOperatorToken> <propertyOrArrayReferenceRule>,当cmdlet调用不能匹配简单属性或数组规则时,该调用将失败,而!(Test-Path ...)可以将括号大小的cmdlet调用作为子表达式匹配。编辑:也见PowerShell 2.0语言规范 (感谢罗曼对另一个问题的回答)。
发布于 2012-04-12 13:35:11
if后面的括号定义了一个子表达式(如果在Test-Path周围需要括号,那么我们将需要在$num -eq 5和所有其他表达式周围使用parens )。需要在not运算符之后加上括号,因为Test-Path需要在被否定之前进行计算。您可以在不使用if语句的情况下尝试此操作。
这样做是行不通的:
PS> !Test-Path NonExistent.file这样做是可行的:
PS> !(Test-Path NonExistent.file)https://stackoverflow.com/questions/10123698
复制相似问题