请注意,发生的情况与任何类型的隐式字符串转换等均无关,而是因为Exception类实现了__getitem
__(),并使用它来返回args元组(ex.args)中的值。您可以通过将整个字符串作为迭代中的第一个也是唯一的项目,而不是遍历字符串而得到的每个字符的结果来看到这一点。
这也让我感到惊讶,但是考虑到这一点,我想这是出于向后兼容的原因。以前(1.5之前的版本)的Python缺少当前类的异常层次结构。相反,将抛出字符串,并使用(通常是)元组参数表示应传递给处理块的任何详细信息。即:
try: raise "something failed", (42, "some other details")except "something failed", args: errCode, msg = args print "something failed. error pre %d: %s" % (errCode, msg)
这样做似乎是为了避免破坏期望参数为元组的1.5之前的代码,而不是不可迭代的异常对象。上面链接的“致命损坏”部分中有一些使用IOError的示例。
字符串异常已经废弃了一段时间,并且在Python 3中逐渐消失。我现在已经检查了Python 3如何处理异常对象,并且看起来它们在那里不再可迭代:
>>> list(Exception("test"))Traceback (most recent call last): File "<stdin>", line 1, in <module>TypeError: 'Exception' object is not iterable
[编辑]检查python3的行为
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)