operator --- 标准运算符对应函数¶
源代码: Lib/operator.py
The operator module exports a set of efficient functions corresponding to
the intrinsic operators of Python. For example, operator.add(x, y) is
equivalent to the expression x+y. Many function names are those used for
special methods, without the double underscores. For backward compatibility,
many of these have a variant with the double underscores kept. The variants
without the double underscores are preferred for clarity.
函数包含的种类有:对象的比较运算、逻辑运算、数学运算以及序列运算。
对象比较函数适用于所有的对象,函数名根据它们对应的比较运算符命名。
- 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 之间进行全比较。具体的,
lt(a, b)与a < b相同,le(a, b)与a <= b相同,eq(a, b)与a == b相同,ne(a, b)与a != b相同,gt(a, b)与a > b相同,ge(a, b)与a >= b相同。注意这些函数可以返回任何值,无论它是否可当作布尔值。关于全比较的更多信息请参考 比较运算 。
逻辑运算通常也适用于所有对象,并且支持真值检测、标识检测和布尔运算:
- operator.not_(obj)¶
- operator.__not__(obj)¶
返回
notobj 的结果。 (请注意对象实例并没有__not__()方法;只有解释器核心可定义此操作。 结果会受到__bool__()和__len__()方法的影响。)
- operator.is_(a, b)¶
返回
a is b。 检测对象标识。
- operator.is_not(a, b)¶
返回
a is not b。 检测对象标识。
- operator.is_none(a)¶
返回
a is None。 检测对象标识。Added in version 3.14.
- operator.is_not_none(a)¶
返回
a is not None。 检测对象标识。Added in version 3.14.
数学和按位运算的种类是最多的:
- operator.index(a)¶
- operator.__index__(a)¶
返回 a 转换为整数的结果。 等价于
a.__index__()。在 3.10 版本发生变更: 结果总是为
int类型。 在之前版本中,结果可能为int的子类的实例。
- operator.inv(obj)¶
- operator.invert(obj)¶
- operator.__inv__(obj)¶
- operator.__invert__(obj)¶
返回数字 obj 按位取反的结果。 这等价于
~obj。
适用于序列的操作(其中一些也适用于映射)包括:
- operator.countOf(a, b)¶
返回 b 在 a 中的出现次数。
- operator.indexOf(a, b)¶
返回 b 在 a 中首次出现所在的索引号。
- operator.length_hint(obj, default=0)¶
返回对象 obj 的估计长度。 首先尝试返回其实际长度,再使用
object.__length_hint__()得出估计值,最后返回默认值。Added in version 3.4.
以下操作适用于可调用对象:
- operator.call(obj, /, *args, **kwargs)¶
- operator.__call__(obj, /, *args, **kwargs)¶
返回
obj(*args, **kwargs)。Added in version 3.11.
The operator module also defines tools for generalized attribute and item
lookups. These are useful for making fast field extractors as arguments for
map(), sorted(), itertools.groupby(), or other functions that
expect a function argument.
- operator.attrgetter(attr)¶
- operator.attrgetter(*attrs)
返回一个可从操作数中获取 attr 的可调用对象。 如果请求了一个以上的属性,则返回一个属性元组。 属性名称还可包含点号。 例如:
在
f = attrgetter('name')之后,调用f(b)将返回b.name。在
f = attrgetter('name', 'date')之后,调用f(b)将返回(b.name, b.date)。在
f = attrgetter('name.first', 'name.last')之后,调用f(b)将返回(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
- operator.itemgetter(item)¶
- operator.itemgetter(*items)
返回一个使用操作数的
__getitem__()方法从操作数中获取 item 的可调用对象。 如果指定了多个条目,则返回一个查找值的元组。 例如:在
f = itemgetter(2)之后,调用f(r)将返回r[2]。在
g = itemgetter(2, 5, 3)之后,调用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__()方法所接受的任何类型。 字典接受任意 hashable 值。 列表、元组和字符串接受索引或切片对象:>>> itemgetter(1)('ABCDEFG') 'B' >>> itemgetter(1, 3, 5)('ABCDEFG') ('B', 'D', 'F') >>> itemgetter(slice(2, None))('ABCDEFG') 'CDEFG' >>> soldier = dict(rank='captain', name='dotterbart') >>> itemgetter('rank')(soldier) 'captain'
使用
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, **kwargs)¶
返回一个在操作数上调用 name 方法的可调用对象。 如果给出额外的参数和/或关键字参数,它们也将被传给该方法。 例如:
在
f = methodcaller('name')之后,调用f(b)将返回b.name()。在
f = methodcaller('name', 'foo', bar=1)之后,调用f(b)将返回b.name('foo', bar=1)。
等价于:
def methodcaller(name, /, *args, **kwargs): def caller(obj): return getattr(obj, name)(*args, **kwargs) return caller
将运算符映射到函数¶
This table shows how abstract operations correspond to operator symbols in the
Python syntax and the functions in the operator module.
运算 |
语法 |
函数 |
|---|---|---|
加法 |
|
|
字符串拼接 |
|
|
包含测试 |
|
|
除法 |
|
|
除法 |
|
|
按位与 |
|
|
按位异或 |
|
|
按位取反 |
|
|
按位或 |
|
|
取幂 |
|
|
标识 |
|
|
标识 |
|
|
标识 |
|
|
标识 |
|
|
索引赋值 |
|
|
索引删除 |
|
|
索引取值 |
|
|
左移 |
|
|
取模 |
|
|
乘法 |
|
|
矩阵乘法 |
|
|
取反(算术) |
|
|
取反(逻辑) |
|
|
正数 |
|
|
右移 |
|
|
切片赋值 |
|
|
切片删除 |
|
|
切片取值 |
|
|
字符串格式化 |
|
|
减法 |
|
|
真值测试 |
|
|
比较 |
|
|
比较 |
|
|
相等 |
|
|
不等 |
|
|
比较 |
|
|
比较 |
|
|
原地运算符¶
许多运算都有“原地”版本。 以下列出的是提供对原地运算符相比通常语法更底层访问的函数,例如 statement x += y 相当于 x = operator.iadd(x, y)。 换一种方式来讲就是 z = operator.iadd(x, y) 等价于语句块 z = x; z += y。
在这些例子中,请注意当调用一个原地方法时,运算和赋值是分成两个步骤来执行的。 下面列出的原地函数只执行第一步即调用原地方法。 第二步赋值则不加处理。
对于不可变的目标例如字符串、数字和元组,更新的值会被计算,但不会被再被赋值给输入变量:
>>> a = 'hello'
>>> iadd(a, ' world')
'hello world'
>>> a
'hello'
对于可变的目标例如列表和字典,原地方法将执行更新,因此不需要后续赋值操作:
>>> 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']