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)¶
在 a 和 b 之間進行 "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)¶
回傳
notobj 的結果。(請注意物件實例並沒有__not__()method(方法);只有直譯器核心定義此操作。結果會受__bool__()和__len__()method 影響。)
- 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.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.neg(obj)¶