我不确定我遇到的问题是我缺乏使用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行?
答案 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}}论证。