Python在错误的行上返回类型错误

时间:2018-02-09 00:03:07

标签: python python-3.6

我不确定我遇到的问题是我缺乏使用Python的经验,或者它是否是解释器中的错误,但我认为我得到的是{{ 1}}消息在错误的行上。

如果不是错误,请向我解释为什么会发生这种情况。我的代码如下:

TypeError

这是我的输出

#!/usr/bin/env python3

from awacs.aws import Policy, Principal, Statement
from troposphere import Template
from troposphere.iam import Role

t = Template()

t.add_resource(Role(
    "SESLambdaRole",
    AssumeRolePolicyDocument = Policy(
        Version = "2012-10-17",
        Statement = [
            Statement(
                Effect = "Allow",
                Resource = "arn:aws:logs:*:*:*",
                Principal = Principal(
                    "Service",
                    ["lambda.amazonaws.com"]
                    ),
                )
            ]
        )
    ))

print(t.to_json())

如果我更改以下行

ubuntu@ip-111-11-11-111:~$ ./ses-lambda-forwarder-resources.py 
Traceback (most recent call last):
  File "./ses-lambda-forwarder-resources.py", line 19, in <module>
    ["lambda.amazonaws.com"]
  File "/home/ubuntu/.local/lib/python3.6/site-packages/awacs/__init__.py", line 113, in __init__
    sup.__init__(None, props=self.props, **kwargs)
  File "/home/ubuntu/.local/lib/python3.6/site-packages/awacs/__init__.py", line 40, in __init__
    self.__setattr__(k, v)
  File "/home/ubuntu/.local/lib/python3.6/site-packages/awacs/__init__.py", line 81, in __setattr__
    self._raise_type(name, value, expected_type)
  File "/home/ubuntu/.local/lib/python3.6/site-packages/awacs/__init__.py", line 90, in _raise_type
    (name, type(value), expected_type))
TypeError: Resource is <class 'str'>, expected <class 'list'>
ubuntu@ip-111-11-11-111:~$ python3 --version
Python 3.6.3

Resource = "arn:aws:logs:*:*:*",

有效。为什么Python会抱怨下面第3行?

1 个答案:

答案 0 :(得分:1)

Python并不知道哪个实际参数存在错误,只是它是从一个延伸到几行的表达式传递出来的。它粗略猜测了错误行(as Ryan points out in the comments似乎是表达式中的最后一个非标点符号行),并将错误报告为来自那里,但它可能来自表达式的任何部分这是错误的。有关更简单的示例,请考虑:

>>> i = int(
...         '#',
...         base=2
...        )
...
---------------------------------------------------------------------------
ValueError                                Traceback (most recent call last)
<ipython-input-6-1e4a194d0c31> in <module>()
      1 i = int(
      2         '#',
----> 3         base=2
      4        )
      5

ValueError: invalid literal for int() with base 2: '#'

错误来自int构造函数(调用从第1行开始),来自'#'参数(第2行),表达式在第4行结束,但箭头表示第3行。所有Python真正知道的是错误来自int(...)表达式,并且它使问题成为表达式的最后有意义的一行,但它并不真正知道哪个参数在错误(异常提升API并不是很细粒度,足以以编程方式告诉Python哪个参数是一个可能有帮助的问题),而启发式方法也不起作用。

你的代码也会发生同样的事情; Python知道Statement构造函数引发了异常,并且当引发错误时它指向该表达式的最后一个非平凡的行,但它并不真正知道哪一行包含有问题的参数,并且启发式为您提供误导性信息。幸运的是,异常消息告诉您错误(Resource参数必须是list),因此您可以使用该上下文扫描附近的行并注意非list { {1}}论证。