我知道我能做到:
try:
# do something that may fail
except:
# do this if ANYTHING goes wrong
Run Code Online (Sandbox Code Playgroud)
我也可以这样做:
try:
# do something that may fail
except IDontLikeYouException:
# say please
except YouAreTooShortException:
# stand on a ladder
Run Code Online (Sandbox Code Playgroud)
但如果我想在两个不同的例外中做同样的事情,我现在能想到的最好的就是这样做:
try:
# do something that may fail
except IDontLikeYouException:
# say please
except YouAreBeingMeanException:
# say please
Run Code Online (Sandbox Code Playgroud)
有什么办法我可以做这样的事情(因为两个例外的行动都是say please):
try:
# do something that may fail
except IDontLikeYouException, YouAreBeingMeanException:
# say please
Run Code Online (Sandbox Code Playgroud)
现在这真的不起作用,因为它符合以下语法:
try:
# do something that may fail
except …Run Code Online (Sandbox Code Playgroud) 除语句中','和'as'之间有什么区别,例如:
try:
pass
except Exception, exception:
pass
Run Code Online (Sandbox Code Playgroud)
和:
try:
pass
except Exception as exception:
pass
Run Code Online (Sandbox Code Playgroud)
第二种语法在2.6中合法吗?它适用于Windows上的CPython 2.6,但cygwin中的2.5解释器抱怨它无效.
如果它们在2.6中都有效,我应该使用哪个?
以下代码在Python 2.5和3.0中按预期工作:
a, b, c = (1, 2, 3)
print(a, b, c)
def test():
print(a)
print(b)
print(c) # (A)
#c+=1 # (B)
test()
Run Code Online (Sandbox Code Playgroud)
但是,当我取消注释行(B)时,我得到了UnboundLocalError: 'c' not assigned一行(A).的值a和b被正确地打印.这让我感到困惑,原因有两个:
为什么在行(A)处抛出运行时错误,因为后面的行(B)语句?
为什么变量a和b打印符合预期,同时c引发错误?
我能想到的唯一解释是,赋值创建了一个局部变量,即使在创建局部变量之前,它也优先于"全局"变量.当然,变量在存在之前"窃取"范围是没有意义的.cc+=1c
有人可以解释一下这种行为吗?
exc = None
try:
raise Exception
except Exception as exc:
pass
# ...
print(exc)
Run Code Online (Sandbox Code Playgroud)
NameError:未定义名称'exc'
这曾经在Python2中工作.为什么这样改变了?如果我至少可以重新分配exc,类似于类级属性
class Foo(object):
Bar = Bar
Run Code Online (Sandbox Code Playgroud)
但这也不能使它工作:
exc = None
try:
raise Exception
except Exception as exc:
exc = exc
Run Code Online (Sandbox Code Playgroud)
有什么好的提示可以实现同样的目标吗?我不想写这样的东西:
exc = None
try:
raise Exception("foo")
except Exception as e:
exc = e
# ...
print(exc)
Run Code Online (Sandbox Code Playgroud)