您通常会听到Python鼓励EAFP风格(“请求宽恕比许可容易”)而不是LBYL风格(“跨越前先看”)。对我来说,这是效率和可读性的问题。
在您的示例中(例如,该函数不是返回列表或空字符串,而是返回列表或None
),如果您希望99%的时间result
实际上包含可迭代的内容,则可以使用该try/except
方法。如果异常确实是例外,它将更快。如果result
是None
的时间超过50%,则使用if
的可能会更好。
为了通过一些测量来支持这一点:
>>> import timeit
>>> timeit.timeit(setup="a=1;b=1", stmt="a/b") # no error checking
0.06379691968322732
>>> timeit.timeit(setup="a=1;b=1", stmt="try:\n a/b\nexcept ZeroDivisionError:\n pass")
0.0829463709378615
>>> timeit.timeit(setup="a=1;b=0", stmt="try:\n a/b\nexcept ZeroDivisionError:\n pass")
0.5070195056614466
>>> timeit.timeit(setup="a=1;b=1", stmt="if b!=0:\n a/b")
0.11940114974277094
>>> timeit.timeit(setup="a=1;b=0", stmt="if b!=0:\n a/b")
0.051202772912802175
因此,尽管一条if
语句总是要花您很多钱,但设置一个try/except
块几乎是免费的。但是当Exception
实际发生时,成本要高得多。
道德:
try/except
用于流程控制完全可以(和“ pythonic”),
- 但当
Exception
s实际上是例外时,这才有意义。
从Python文档中:
东亚自由贸易区
寻求宽恕比允许容易。这种通用的Python编码风格假设存在有效的键或属性,并且在假设被证明为假的情况下捕获异常。这种干净快捷的样式的特点是存在许多
try
和except
声明。该技术与
许多其他语言(例如C)通用的LBYL风格形成对比。