Pythonにおけるoperatorモジュールのオペレータ使用例のまとめ

8543 ワード

Operatorモジュールはpythonに内蔵されたオペレータ関数インタフェースで、いくつかの算術と比較内蔵操作の関数を定義します.Operatorモジュールはcで実現されるのでpythonコードよりも実行速度が速い.
ろんりそうさ

from operator import *

a = [1, 2, 3]
b = a
print 'a =', a
print 'b =', b
print 

print 'not_(a)   :', not_(a)
print 'truth(a)   :', truth(a)
print 'is_(a, b)  :', is_(a, b)
print 'is_not(a, b) :', is_not(a, b)


印刷結果:

a = [1, 2, 3]
b = [1, 2, 3]
not_(a)   : False
truth(a)  : True
is_(a, b)  : True
is_not(a, b): False

結果からoperatorのいくつかの操作関数は元の演算と同じであることがわかる.
比較オペレータoperatorは豊富な比較操作を提供します.

a = 3
b = 5
print 'a =', a
print 'b =', b
print 

for func in (lt, le, eq, ne, ge, gt):
  print '{0}(a, b):'.format(func.__name__), func(a, b)


印刷結果

a = 3
b = 5

lt(a, b): True
le(a, b): True
eq(a, b): False
ne(a, b): True
ge(a, b): False
gt(a, b): False


これらの関数は、=および>の式構文に等価です.
算術オペレータが数値を処理する算術オペレータもサポートされています.

a, b, c, d = -1, 2, -3, 4

print 'a =', a
print 'b =', b
print 'c =', c
print 'd =', d
 
print '
Positive/Negative:' print 'abs(a):', abs(a) print 'neg(a):', neg(a) print 'neg(b):', neg(b) print 'pos(a):', pos(a) print 'pos(b):', pos(b)

印刷結果

a = -1
b = 2
c = -3
d = 4

Positive/Negative:
abs(a): 1
neg(a): 1
neg(b): -2
pos(a): -1
pos(b): 2


absは絶対値を返し,negは(-obj),posは(+obj)を返す.

a = -2
b = 5.0

print 'a =', a
print 'b =', b
 
print '
Arithmetic' print 'add(a, b) :', add(a, b) print 'div(a, b) :', div(a, b) print 'floordiv(a, b) :', floordiv(a, b) print 'mod(a, b) :', mod(a, b) print 'mul(a, b) :', mul(a, b) print 'pow(a, b) :', pow(a, b) print 'sub(a, b) :', sub(a, b) print 'truediv(a, b) :', truediv(a, b)

印刷結果

a = -2
b = 5.0

Arithmetic
add(a, b)    : 3.0
div(a, b)    : -0.4
floordiv(a, b)  : -1.0
mod(a, b)    : 3.0 #       
mul(a, b)    : -10.0
pow(a, b)    : -32.0
sub(a, b)    : -7.0
truediv(a, b)  : -0.4


modは型取り、mulは乗算、powは次数、subは減算

a = 2
b = 6

print 'a =', a
print 'b =', b

print '
Bitwise:' print 'and_(a, b) :', and_(a, b) print 'invert(a) :', invert(a) print 'lshift(a, b) :', lshift(a, b) print 'or_(a, b) :', or_(a, b) print 'rshift(a, b) :', rshift(a, b) print 'xor(a, b) :', xor(a, b)

印刷結果

a = 2
b = 6

Bitwise:
and_(a, b)  : 2
invert(a)  : -3
lshift(a, b) : 128
or_(a, b)  : 6
rshift(a, b) : 0
xor(a, b)  : 4


andはビット別と、invertは取反操作、lshiftは左シフト、orはビット別または、rshiftは右シフト、xorはビット別またはを表す.
その場オペレータはin-place操作であり、x+=yはx=iadd(x,y)に等しく、z=iadd(x,y)などの他の変数にコピーされた場合はz=xに等しい.z += y.

a = 3
b = 4
c = [1, 2]
d = ['a', 'b']

print 'a =', a
print 'b =', b
print 'c =', c
print 'd =', d
print

a = iadd(a, b)
print 'a = iadd(a, b) =>', a
print

c = iconcat(c, d)
print 'c = iconcat(c, d) =>', c


属性と要素の取得方法operatorモジュールの最も特別な特性の一つは取得方法の概念であり、取得方法は実行時に構築されたいくつかのコールバック可能なオブジェクトであり、オブジェクトの属性またはシーケンスの内容を取得するために使用され、取得方法は反復器またはジェネレータシーケンスを処理する際に特に有用であり、それらが導入したオーバーヘッドはlambdaまたはPython関数のオーバーヘッドを大幅に低減する.

from operator import *
class MyObj(object):
  def __init__(self, arg):
    super(MyObj, self).__init__()
    self.arg = arg
  def __repr__(self):
    return 'MyObj(%s)' % self.arg

objs = [MyObj(i) for i in xrange(5)]
print "Object:", objs

g = attrgetter("arg")
vals = [g(i) for i in objs]
print "arg values:", vals

objs.reverse()
print "reversed:", objs
print "sorted:", sorted(objs, key=g)


結果:

Object: [MyObj(0), MyObj(1), MyObj(2), MyObj(3), MyObj(4)]
arg values: [0, 1, 2, 3, 4]
reversed: [MyObj(4), MyObj(3), MyObj(2), MyObj(1), MyObj(0)]
sorted: [MyObj(0), MyObj(1), MyObj(2), MyObj(3), MyObj(4)]

プロパティの取得方法は

lambda x, n='attrname':getattr(x,nz)

要素の取得方法は

lambda x,y=5:x[y]

from operator import *

l = [dict(val=-1*i) for i in xrange(4)]
print "dictionaries:", l
g = itemgetter("val")
vals = [g(i) for i in l]
print "values: ", vals
print "sorted:", sorted(l, key=g)

l = [(i,i*-2) for i in xrange(4)]
print "tuples: ", l
g = itemgetter(1)
vals = [g(i) for i in l]
print "values:", vals
print "sorted:", sorted(l, key=g)


結果は次のとおりです.

dictionaries: [{'val': 0}, {'val': -1}, {'val': -2}, {'val': -3}]
values: [0, -1, -2, -3]
sorted: [{'val': -3}, {'val': -2}, {'val': -1}, {'val': 0}]
tuples: [(0, 0), (1, -2), (2, -4), (3, -6)]
values: [0, -2, -4, -6]
sorted: [(3, -6), (2, -4), (1, -2), (0, 0)]

シーケンスに加えて、要素取得方法はマッピングにも適しています.
オペレータとカスタムクラスoperatorモジュールの関数を組み合わせて、対応する操作の標準Pythonインタフェースで作業を完了するため、組み込みタイプだけでなく、ユーザーのカスタムタイプにも適しています.

from operator import *

class MyObj(object):
  def __init__(self, val):
    super(MyObj, self).__init__()
    self.val = val
    return 

  def __str__(self):
    return "MyObj(%s)" % self.val

  def __lt__(self, other):
    return self.val < other.val

  def __add__(self, other):
    return MyObj(self.val + other.val)

a = MyObj(1)
b = MyObj(2)

print lt(a, b)
print add(a,b)


結果は次のとおりです.

True
MyObj(3)

タイプチェックoperatorモジュールには、マッピング、数値、シーケンスタイプのAPI互換性をテストするための関数も含まれています.

from operator import *

class NoType(object):
  pass

class MultiType(object):
  def __len__(self):
    return 0

  def __getitem__(self, name):
    return "mapping"

  def __int__(self):
    return 0

o = NoType()
t = MultiType()

for func in [isMappingType, isNumberType, isSequenceType]:
  print "%s(o):" % func.__name__, func(o)
  print "%s(t):" % func.__name__, func(t)


結果は次のとおりです.

isMappingType(o): False
isMappingType(t): True
isNumberType(o): False
isNumberType(t): True
isSequenceType(o): False
isSequenceType(t): True

しかし、これらのテストは完璧ではありません.言い訳は厳密に定義されていないからです.
オブジェクトの取得方法methodcallerを使用してオブジェクトを取得する方法.

from operator import methodcaller

class Student(object):
  def __init__(self, name):
    self.name = name

  def getName(self):
    return self.name

stu = Student("Jim")
func = methodcaller('getName')
print func(stu)  #   Jim


メソッドにパラメータを渡すこともできます.

f=methodcaller('name', 'foo', bar=1)
f(b)  # return  b.name('foo', bar=1)
methodcaller           :

def methodcaller(name, *args, **kwargs):
   def caller(obj):
      return getattr(obj, name)(*args, **kwargs)
   return caller