Python 打印:字符串格式错误

Python print: error with string formatting

在使用 fabric 一段时间后,我一直在尝试将 boto3 合并到我的 AWS 工作流程中。刚开始学习 Python 所以对于其中的一些问题提前表示歉意。我用下面的脚本搜索并调试了我能做的,因为大多数错误似乎都是在 Python2 中编写的,而我在 OSX 上使用 Python3。很抱歉格式问题,并尝试将脚本放入此处的代码块中。

    #!/usr/bin/env python
    import boto3
    import sys
    import argparse
    import paramiko


def list_instances(Filter):
    ec2 = boto3.resource('ec2')
    instances = ec2.instances.filter(Filters=Filter)
    columns_format = ("%-3s %-26s %-16s %-16s %-20s %-12s %-12s %-16s")
    print (columns_format) ("num", "Name", "Public IP", "Private IP", "ID", 
    "Type", "VPC", "Status")
    num = 1
    hosts = [] 
    name = {}  
    for i in instances:
        try:
            name = (item for item in i.tags if item["Key"] == "Name" ).next()
        except StopIteration:
            name['Value'] = ''

        print (columns_format) % (
                           num,
                           name['Value'], 
                           i.public_ip_address,
                           i.private_ip_address,
                           i.id,
                           i.instance_type,
                           i.vpc_id,
                           i.state['Name']
                         )
      num = num + 1
      item={'id': i.id, 'ip': i.public_ip_address, 'hostname': 
      name['Value'], 'status': i.state['Name'],}
      hosts.append(item)

  return hosts

def execute_cmd(host,user,cmd):
    ssh = paramiko.SSHClient()
    ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
    try:
       ssh.connect(host, username=user)
       stdin, stdout, stderr = ssh.exec_command(cmd)
       stdout=stdout.read()
       stderr=stderr.read()
       ssh.close()
       return stdout,stderr
    except paramiko.AuthenticationException as exception: 
       return "Authentication Error trying to connect into the host %s with     the user %s. Plese review your keys" % (host, user), e 

def main():
    parser = argparse.ArgumentParser()
    parser.add_argument('-n', '--name',
                    help="Filter result by name.")
    parser.add_argument('-t', '--type',
                    help="Filer result by type.")
    parser.add_argument('-s', '--status',
                    help="Filter result by status." )
    parser.add_argument('-e', '--execute',
                    help="Execute a command on instances")
    parser.add_argument('-u', '--user', default="ubuntu",
                    help="User to run commands if -e option is used.\
                          Ubuntu user is used by default")

    arg = parser.parse_args()

    # Default filter if no options are specified
    filter=[]

    if arg.name:
        filter.append({'Name': 'tag-value', 'Values': ["*" + arg.name + "*"]})

    if arg.type:
        filter.append({'Name': 'instance-type', 'Values': ["*" + arg.type + "*"]})

    if arg.status:
        filter.append({'Name': 'instance-state-name', 'Values': ["*" + arg.status + "*"]})

    hosts=list_instances(filter)
    names = ""

    if arg.execute:
       for item in hosts:
          names = names + " " + item["hostname"] + "(" + item["id"] + ")"
       print ("\nCommand to execute: %s") % arg.execute
       print ("Executed by: %s") % arg.user
       print ("Hosts list: %s\n") % names 
       for item in hosts:
          if item["status"] == 'running':
             print ("::: %s (%s)") % (item["hostname"], item["id"])
             stdout,stderr = execute_cmd(item["ip"], arg.user, arg.execute)
             print (stdout) 
             print (stderr)
          else:
             print ("::: %s (%s) is not running (command execution skiped)") % (item["hostname"], item["id"])

if __name__ == '__main__':
sys.exit(main())

从终端执行:python ec2-instances.py

并得到以下输出:

%-3s %-26s %-16s %-16s %-20s %-12s %-12s %-16s
Traceback (most recent call last):
File "ec2-instances.py", line 97, in <module>
sys.exit(main())
File "ec2-instances.py", line 78, in main
hosts=list_instances(filter)
File "ec2-instances.py", line 12, in list_instances
print (columns_format) ("num", "Name", "Public IP", "Private IP", "ID", 
"Type", "VPC", "Status")
TypeError: 'NoneType' object is not callable

在此先感谢您的帮助!

我认为你的问题只是你不能像这样调用 print:

print (columns_format) ("num", "Name", "Public IP", "Private IP", "ID", 
"Type", "VPC", "Status")

因为 print(arguments) (arguments) 试图调用一个函数

尝试将其替换为(我猜 % 刚刚丢失)

print ((columns_format) % ("num", "Name", "Public IP", "Private IP", "ID", 
"Type", "VPC", "Status"))