【问题标题】:Passing Windows cmd to the Python subprocess将 Windows cmd 传递给 Python 子进程
【发布时间】:2021-06-29 16:54:27
【问题描述】:

我正在尝试使用 Pyton 的子进程执行 aws cli 命令

windows cmd:

aws --profile some_profile --region some_region ec2 describe-instances --filters Name=tag:some_tag,Values=some_value --query "Reservations[*].Instances[*].{AvailabilityZone:Placement.AvailabilityZone,Status:State.Name,Name:Tags[?Key=='Name']|[0].Value}" --output=table

我就是这样做的:

profile = "some_profile"
region = "some_region"
ec2_filters = "Name=tag:some_tag,Values=some_value"
ec2_query = "Reservations[*].Instances[*].{AvailabilityZone:Placement.AvailabilityZone,Status:State.Name,Name:Tags[?Key=='Name']|[0].Value}"
ec2_output_type = "table"

proc = subprocess.Popen(["aws", "--profile", profile, "--region", region, "ec2", "describe-instances", "--filters", ec2_filters, "--query", ec2_query, "--output", ec2_output_type], stdout=subprocess.PIPE, shell=True)

这是错误信息:

'[0].Value}' 未被识别为内部或外部命令, 可运行的程序或批处理文件。

【问题讨论】:

  • 尝试在您的查询中添加一组额外的引号,'"Reservations[*].Instances[*].{AvailabilityZone:Placement.AvailabilityZone,Status:State.Name,Name:Tags[?Key=='Name']|[0].Value}'"
  • 我试过了,但它说:SyntaxError: invalid syntax。我也尝试了另一种方式(内部单引号),例如“'query_here'”,但随后出现类似错误:'[0].Value}'' 不被识别为内部或外部命令、可运行程序或批处理文件.
  • 哦,我没有注意到你的命令中的单引号。然后尝试三引号。 ec2_query = '''"Reservations[*].Instances[*].{AvailabilityZone:Placement.AvailabilityZone,Status:State.Name,Name:Tags[?Key=='Name']|[0].Value}"'''
  • 这个三引号字符串将注释我的变量的值:)
  • 我不明白。三引号字符串不是 cmets,它们只是字符串。您可以随心所欲地使用它们。

标签: python cmd subprocess popen


【解决方案1】:

我没有安装 aws,所以我创建了一个模拟批处理文件来返回它收到的内容。我确实尝试了我最初的猜测,你是对的,这通常会使它变得困难,但我想通了。很抱歉没有测试我让你尝试的东西。

无论如何,aws.bat 包含一行 echo %*,它将打印回批处理文件作为参数接收到的任何内容,因此我们知道它正在工作。

然后,我尝试使用您的命令。我遇到了同样的错误,所以我将其修改为:

.\aws.bat --profile some_profile --region some_region ec2 describe-instances --filters Name=tag:some_tag,Values=some_value --query '"Reservations[*].Instances[*].{AvailabilityZone:Placement.AvailabilityZone,Status:State.Name,Name:Tags[?Key=='Name']|[0].Value}"' --output=table

这将命令输出回来,意味着它被正确执行了。

然后,我修改了您的代码以确保所有查询都有引号。我使用简单的字符串连接来做到这一点。

import subprocess
profile = "some_profile"
region = "some_region"
ec2_filters = "Name=tag:some_tag,Values=some_value"
ec2_query = (
    '"Reservations[*].Instances[*].{AvailabilityZone:Placement.AvailabilityZone,Status:State.Name,Name:Tags[?Key=='
    "'Name'" 
    ']|[0].Value}"'
)
ec2_output_type = "table"

proc = subprocess.Popen(["aws.bat", "--profile", profile, "--region", region, "ec2", "describe-instances", "--filters", ec2_filters, "--query", ec2_query, "--output", ec2_output_type])

这行得通。有趣的是,如果我以非正统的方式使用三引号,它也同样有效。

ec2_query = ' '''"Reservations[*].Instances[*].{AvailabilityZone:Placement.AvailabilityZone,Status:State.Name,Name:Tags[?Key=='Name']|[0].Value}"' '''

注意开头,' '''"。我真的不知道发生了什么。

无论如何,更简单的解决方案是将字符串拆分,这样引号就不会混淆。

【讨论】:

  • 太好了,它有效!你是对的,打破那个字符串可能是最好的解决方案。
猜你喜欢
  • 1970-01-01
  • 2018-09-29
  • 2021-06-13
  • 1970-01-01
  • 2019-12-26
  • 1970-01-01
  • 2015-07-08
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多