operator --- 標準運算子替代函式

原始碼:Lib/operator.py


operator module(模組)提供了一套與 Python 原生運算子對應的高效率函式。例如,operator.add(x, y) 與表示式 x+y 相同。許多函式名與特殊方法名相同,只是沒有雙底線。為了向後相容,許多包含雙底線的函式被保留了下來,但為了易於表達,建議使用沒有雙底線的函式。

函式種類有物件的比較運算、邏輯運算、數學運算以及序列運算。

物件比較函式適用於所有物件,函式根據它們對應的 rich comparison 運算子命名:

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)

ab 之間進行 "rich comparison"。具體來說,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 相同。注意這些函式可以回傳任何值,無論它是否可當作 boolean(布林)值。關於 rich comparison 的更多資訊請參考 Comparisons

邏輯運算通常也適用於所有物件,並且支援真值檢測、識別性測試和 boolean 運算:

operator.not_(obj)
operator.__not__(obj)

回傳 not obj 的結果。(請注意物件實例並沒有 __not__() method(方法);只有直譯器核心定義此操作。結果會受 __bool__()__len__() method 影響。)

operator.truth(obj)

如果 obj 為真值則回傳 True,否則回傳 False。這等價於使用 bool 建構函式。

operator.is_(a, b)

回傳 a is b。測試物件識別性。

operator.is_not(a, b)

回傳 a is not b。測試物件識別性。

operator.is_none(a)

回傳 a is None。測試物件識別性。

在 3.14 版被加入.

operator.is_not_none(a)

回傳 a is not None。測試物件識別性。

在 3.14 版被加入.

數學和位元運算的種類是最多的:

operator.abs(obj)
operator.__abs__(obj)

回傳 obj 的絕對值。

operator.add(a, b)
operator.__add__(a, b)

對於數字 ab,回傳 a + b

operator.and_(a, b)
operator.__and__(a, b)

回傳 xy 位元運算與 (and) 的結果。

operator.floordiv(a, b)
operator.__floordiv__(a, b)

回傳 a // b

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 按位元取反 (inverse) 的結果。這等價於 ~obj

operator.lshift(a, b)
operator.__lshift__(a, b)

回傳 a 左移 b 位的結果。

operator.mod(a, b)
operator.__mod__(a, b)

回傳 a % b

operator.mul(a, b)
operator.__mul__(a, b)

對於數字 ab,回傳 a * b

operator.matmul(a, b)
operator.__matmul__(a, b)

回傳 a @ b

在 3.5 版被加入.

operator.neg(obj)
operator.__neg__(obj)

回傳 obj 取負值的結果 (-obj)。

operator.or_(a, b)
operator.__or__(a, b)

回傳 ab 按位元或 (or) 的結果。

operator.pos(obj)
operator.__pos__(obj)

回傳 obj 取正的結果 (+obj)。

operator.pow(a, b)
operator.__pow__(a, b)

對於數字 ab,回傳 a ** b

operator.rshift(a, b)
operator.__rshift__(a, b)

回傳 a 右移 b 位的結果。

operator.sub(a, b)
operator.__sub__(a, b)

回傳 a - b

operator.truediv(a, b)
operator.__truediv__(a, b)

回傳 a / b,例如 2/3 將等於 .66 而不是 0。這也被稱為「真」除法。

operator.xor(a, b)
operator.__xor__(a, b)

回傳 ab 按位元異或 (exclusive or) 的結果。

適用於序列的操作(其中一些也適用於對映 (mapping)),包括:

operator.concat(a, b)
operator.__concat__(a, b)

對於序列 ab,回傳 a + b

operator.contains(a, b)
operator.__contains__(a, b)

回傳 b in a 檢測的結果。請注意運算元是反序的。

operator.countOf(a, b)

回傳 ba 中的出現次數。

operator.delitem(a, b)
operator.__delitem__(a, b)

移除 a 中索引為 b 的值。

operator.getitem(a, b)
operator.__getitem__(a, b)

回傳 a 中索引為 b 的值。

operator.indexOf(a, b)

回傳 ba 中首次出現所在的索引。

operator.setitem(a, b, c)
operator.__setitem__(a, b, c)

a 中索引為 b 的值設為 c

operator.length_hint(obj, default=0)

回傳物件 obj 的估計長度。首先嘗試回傳其實際長度,再使用 object.__length_hint__() 得出估計值,最後才是回傳預設值。

在 3.4 版被加入.

以下操作適用於可呼叫物件:

operator.call(obj, /, *args, **kwargs)
operator.__call__(obj, /, *args, **kwargs)

回傳 obj(*args, **kwargs)

在 3.11 版被加入.

operator module 還定義了一些用於常規屬性和條目查詢的工具。這些工具適合用來編寫快速欄位提取器以作為 map()sorted()itertools.groupby() 或其他需要函式引數的函式之引數。

operator.attrgetter(attr)
operator.attrgetter(*attrs)

回傳一個可從運算元中取得 attr 的可呼叫 (callable) 物件。如果請求了一個以上的屬性,則回傳一個包含屬性的 tupple(元組)。屬性名稱還可包含點號。例如:

  • 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('屬性名稱必須是一個字串')
    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 的可呼叫物件。如果指定了多個條目,則回傳一個查詢值的 tupple。例如:

  • f = itemgetter(2) 之後,呼叫 f(r) 將回傳 r[2]

  • g = itemgetter(2, 5, 3) 之後,呼叫