19

这可能是一个愚蠢的问题,但是在查看运算符到函数的映射时,我注意到没有函数可以表达not in运算符。起初我认为这可能是因为解释器只是将它重新排序为not x in y,但是有一个函数is not似乎应该与not in. 我错过了什么,还是那个运营商真的不存在?

这是一个非常愚蠢的例子,你可能想要这个:

def compare_iter(a,b,func):
    return [func(aa,bb) for aa,bb in zip(a,b)]

my_compare=compare_iter(xx,yy,lambda x,y:x not in y)  #lambda -- yuck
my_compare=map(operator.not_,compare_iter(xx,yy,operator.contains)  #extra map?  grr...
#it would be nice to do: my_compare=compare_iter(xx,yy,operator.not_contains)

当然,我可以为此编写自己的函数,但是您会为效率付出代价,而操作员模块可以将此代码从 python 中推出,因此执行得更快。

4

2 回答 2

15

此处不需要其他功能。not in是 的倒数in,因此您有以下映射:

obj in seq => contains(seq, obj)

obj not in seq => not contains(seq, obj)

is你是对的,这与/不一致is not,因为身份测试应该是对称的。这可能是一个设计工件。

于 2012-07-11T14:48:53.983 回答
4

您可能会发现以下函数和反汇编有助于理解运算符:

>>> def test():
        if 0 in (): pass
        if 0 not in (): pass
        if 0 is (): pass
        if 0 is not (): pass
        return None

>>> dis.dis(test)
  2           0 LOAD_CONST               1 (0) 
              3 LOAD_CONST               2 (()) 
              6 COMPARE_OP               6 (in) 
              9 POP_JUMP_IF_FALSE       15 
             12 JUMP_FORWARD             0 (to 15) 

  3     >>   15 LOAD_CONST               1 (0) 
             18 LOAD_CONST               3 (()) 
             21 COMPARE_OP               7 (not in) 
             24 POP_JUMP_IF_FALSE       30 
             27 JUMP_FORWARD             0 (to 30) 

  4     >>   30 LOAD_CONST               1 (0) 
             33 LOAD_CONST               4 (()) 
             36 COMPARE_OP               8 (is) 
             39 POP_JUMP_IF_FALSE       45 
             42 JUMP_FORWARD             0 (to 45) 

  5     >>   45 LOAD_CONST               1 (0) 
             48 LOAD_CONST               5 (()) 
             51 COMPARE_OP               9 (is not) 
             54 POP_JUMP_IF_FALSE       60 
             57 JUMP_FORWARD             0 (to 60) 

  6     >>   60 LOAD_CONST               0 (None) 
             63 RETURN_VALUE         
>>> 

如您所见,每个运算符都有所不同;它们的代码(按顺序)是 6、7、8 和 9。

于 2012-07-11T15:34:58.637 回答