10.3. operator
- 标准运算符作为函数¶
源代码: Lib / operator.py
operator
模块导出一组对应于Python内在运算符的高效函数。例如,operator.add(x, y)
等效于表达式x+y
。函数名是用于特殊类方法的那些;为方便起见,还提供了没有前导和尾随__
的变体。
这些函数分为执行对象比较,逻辑运算,数学运算和序列运算的类别。
对象比较函数对所有对象都很有用,并且以它们支持的丰富比较运算符命名:
operator.
lt
(a, b)¶operator.
le
(a, b)¶operator.
eq
(a, b)¶operator.
ne
(a, b)¶-
operator.
ge
(a, b)¶ operator.
gt
(a, b)¶-
operator.
__lt__
(a, b)¶ -
operator.
__le__
(a, b)¶ -
operator.
__eq__
(a, b)¶ operator.
__ne__
(a, b)¶operator.
__ge__
(a, b)¶operator.
__gt__
(a, b)¶在a和b之间执行“丰富比较”。Specifically,
lt(a, b)
is equivalent toa < b
,le(a, b)
is equivalent toa <= b
,eq(a, b)
is equivalent toa == b
,ne(a, b)
is equivalent toa != b
,gt(a, b)
is equivalent toa > b
andge(a, b)
is equivalent toa >= b
. 注意,这些函数可以返回任何值,这些值可以或可以不被解释为布尔值。有关丰富比较的详细信息,请参见Comparisons。
逻辑操作也通常适用于所有对象,并支持真值测试,身份测试和布尔运算:
operator.
not_
(obj)¶operator.
__not__
(obj)¶返回
not
obj。(请注意,对象实例没有__not__()
方法;只有解释器核定义了此操作。结果受到__bool__()
和__len__()
方法的影响。)
operator.
is_
(a, b)¶返回
a 是 b
。测试对象标识。
-
operator.
is_not
(a, b)¶ 返回
a 是 不是 b
。测试对象标识。
数学和按位操作是最多的:
operator.
inv
(obj)¶operator.
invert
(obj)¶operator.
__inv__
(obj)¶operator.
__invert__
(obj)¶返回数字obj的按位逆。这相当于
~obj
。
使用序列(其中一些与映射)的操作包括:
operator.
countOf
(a, b)¶返回a中b的出现次数。
operator.
indexOf
(a, b)¶返回a中b的第一个出现的索引。
operator.
length_hint
(obj, default=0)¶返回对象o的估计长度。首先尝试返回其实际长度,然后使用
object.__length_hint__()
进行估计,最后返回默认值。版本3.4中的新功能。
operator
模块还定义了用于广义属性和项查找的工具。这些对于使快速字段提取器作为map()
,sorted()
,itertools.groupby()
或其他函数期望一个函数参数。
operator.
attrgetter
(attr)¶operator.
attrgetter
(*attrs)返回从其操作数获取attr的可调用对象。如果请求多个属性,则返回一个属性元组。属性名称也可以包含点。例如:
- After
f = attrgetter('name')
, the callf(b)
returnsb.name
. - 在
f = attrgetter('name', 'date')
调用f(b)
返回(b.name, b.date)
。 - After
f = attrgetter('name.first', 'name.last')
, the callf(b)
returns(b.name.first, b.name.last)
.
相当于:
def attrgetter(*items): if any(not isinstance(item, str) for item in items): raise TypeError('attribute name must be a string') if len(items) == 1: attr = items[0] def g(obj): return resolve_attr(obj, attr) else: def g(obj): return tuple(resolve_attr(obj, attr) for attr in items) return g def resolve_attr(obj, attr): for name in attr.split("."): obj = getattr(obj, name) return obj
- After
operator.
itemgetter
(item)¶operator.
itemgetter
(*items)返回使用操作数的
__getitem__()
方法从其操作数获取项的可调用对象。如果指定了多个项,则返回查找值的元组。例如:- 在
f = itemgetter(2)
之后,调用f(r)
返回r[2]
。 g = itemgetter(2, 5, 3) / t0>,则调用
g(r)
返回(r [2], r [5], r [3])
。
相当于:
def itemgetter(*items): if len(items) == 1: item = items[0] def g(obj): return obj[item] else: def g(obj): return tuple(obj[item] for item in items) return g
这些项可以是操作数的
__getitem__()
方法接受的任何类型。字典接受任何哈希值。列表,元组和字符串接受索引或切片:>>> itemgetter(1)('ABCDEFG') 'B' >>> itemgetter(1,3,5)('ABCDEFG') ('B', 'D', 'F') >>> itemgetter(slice(2,None))('ABCDEFG') 'CDEFG'
使用
itemgetter()
从元组记录中检索特定字段的示例:>>> inventory = [('apple', 3), ('banana', 2), ('pear', 5), ('orange', 1)] >>> getcount = itemgetter(1) >>> list(map(getcount, inventory)) [3, 2, 5, 1] >>> sorted(inventory, key=getcount) [('orange', 1), ('banana', 2), ('apple', 3), ('pear', 5)]
- 在
operator.
methodcaller
(name[, args...])¶返回在其操作数上调用方法name的可调用对象。如果给出了额外的参数和/或关键字参数,它们也将被给予方法。例如:
- After
f = methodcaller('name')
, the callf(b)
returnsb.name()
. f = methodcaller('name', 'foo', bar = 1 )
,则调用f(b)
返回(b.name,b.foo, bar = 1);
。
相当于:
def methodcaller(name, *args, **kwargs): def caller(obj): return getattr(obj, name)(*args, **kwargs) return caller
- After
10.3.1.将运算符映射到函数¶
此表显示抽象操作如何对应于Python语法中的操作符号以及operator
模块中的函数。
操作 | 句法 | 功能 |
---|---|---|
加 | a + b | add(a, b) |
串联 | seq1 + seq2 | concat(seq1, seq2) |
成员测试 | obj in seq | 包含(seq, obj) |
除 | a / b | truediv(a, b) |
整除 | a // b | floordiv(a, b) |
按位与 | a &amp; b | and_(a, b) |
按位异或 | a ^ b | xor(a, b) |
按位取反 | 〜 a | invert(a) |
按位或 | a | b | or_(a, b) |
取幂 | a ** b | pow(a, b) |
身份运算 | a 是 b | is_(a, b) |
身份运算 | a 是 不是 b | is_not(a, b) |
索引分配 | obj [k] = v | setitem(obj, k, v) |
索引删除 | del obj [k] | delitem(obj, k) |
索引取值 | obj[k] | getitem(obj, k) |
左移 | a b | lshift(a, b) |
取模 | a % b | mod(a, b) |
乘 | a * b | mul(a, b) |
矩阵乘法 | a @ b | matmul(a, b) |
取负 | - a | neg(a) |
逻辑非 | 不是 a | not_(a) |
取正 | + a | pos(a) |
右移 | a >&gt; b | rshift(a, b) |
切片赋值 | seq [i:j] = 值 | setitem(seq, slice(i, j), values) |
删除切片 | del seq [i:j] | delitem(seq, slice(i, j)) |
切片 | seq[i:j] | getitem(seq, slice(i, j)) |
取模(同%) | s % obj | mod(s, obj) |
减 | a - b | sub(a, b) |
真相测试 | obj | truth(obj) |
小于 | a b | lt(a, b) |
小于等于 | a b | le(a, b) |
等于 | a == b | eq(a, b) |
不等于 | a != b | ne(a, b) |
大于等于 | a > = b | ge(a, b) |
大于 | a > b | gt(a, b) |
10.3.2。Inplace运算符¶
许多操作都有“in-place”版本。下面列出的是比通常的语法提供对原位操作符更原始的访问的函数;例如statement x + = y
等效于x = operator.iadd(x, y)
。Another way to put it is to say that z = operator.iadd(x, y)
is equivalent to the compound statement z = x; z += y
.
在这些示例中,请注意,当调用就地方法时,计算和分配在两个单独的步骤中执行。下面列出的就地函数仅执行第一步,调用就地方法。第二步,赋值,不处理。
对于不可变目标(如字符串,数字和元组),计算更新的值,但不会分配回输入变量:
>>> a = 'hello'
>>> iadd(a, ' world')
'hello world'
>>> a
'hello'
对于可变目标(如列表和字典),inplace方法将执行更新,因此不需要后续分配:
>>> s = ['h', 'e', 'l', 'l', 'o']
>>> iadd(s, [' ', 'w', 'o', 'r', 'l', 'd'])
['h', 'e', 'l', 'l', 'o', ' ', 'w', 'o', 'r', 'l', 'd']
>>> s
['h', 'e', 'l', 'l', 'o', ' ', 'w', 'o', 'r', 'l', 'd']
-
operator.
iconcat
(a, b)¶ operator.
__iconcat__
(a, b)¶a = iconcat(a, b)
is equivalent toa += b
for a and b sequences.