将if-else嵌套为单行

时间:2012-12-21 16:51:13

标签: syntax python-3.x

如何编写以下嵌套if-else

        if 'parent' in commit:
            if commit['parent'] == cid-1:
                parent = '    '
            else:
                parent = commit['parent']
        else:
            parent = '<no parent>'

作为单线?外部的if-else可以写成

parent = commit['parent'] if 'parent' in commit else '<no parent>'

请描述如何在语法上为复杂表达式编写它,通常不仅适用于这种情况。但请将此示例用作展示。

1 个答案:

答案 0 :(得分:3)

是的,如果将“内部”表达式与外部表达式结合起来,您的代码将作为单行使用:

parent = ('    ' if comment['parent'] == cid-1 else commit['parent']) if 'parent' in commit else '<no parent>'

首先评估外部表达式的if;看看上面'美女'的编译字节码:

>>> import dis
>>> def foo():
...     parent = ('    ' if comment['parent'] == cid-1 else commit['parent']) if 'parent' in commit else '<no parent>'
... 
>>> dis.dis(foo)
  2           0 LOAD_CONST               1 ('parent') 
              3 LOAD_GLOBAL              0 (commit) 
              6 COMPARE_OP               6 (in) 
              9 POP_JUMP_IF_FALSE       48 
             12 LOAD_GLOBAL              1 (comment) 
             15 LOAD_CONST               1 ('parent') 
             18 BINARY_SUBSCR        
             19 LOAD_GLOBAL              2 (cid) 
             22 LOAD_CONST               2 (1) 
             25 BINARY_SUBTRACT      
             26 COMPARE_OP               2 (==) 
             29 POP_JUMP_IF_FALSE       38 
             32 LOAD_CONST               3 ('    ') 
             35 JUMP_ABSOLUTE           51 
        >>   38 LOAD_GLOBAL              0 (commit) 
             41 LOAD_CONST               1 ('parent') 
             44 BINARY_SUBSCR        
             45 JUMP_FORWARD             3 (to 51) 
        >>   48 LOAD_CONST               4 ('<no parent>') 
        >>   51 STORE_FAST               0 (parent) 
             54 LOAD_CONST               0 (None) 
             57 RETURN_VALUE         

因此,如果在'parent'中找到commit 而不是,它将跳转到指令48并加载'<no parent>'而不是commit['parent']毕竟。

不确定该行的可读性,我发现您的显式版本更容易理解。