【Python】operator模块

Python中operator模块提供了一套与 Python 的内置运算符对应的高效率函数。

不仅对应内置运算符,还可以获取方法。可优化涉及回调函数的运算性能,比lambda、Python函数的开销小、速度快。

import operator[x for x in dir(operator) if not x.startswith('_')]
# 结果:
['abs', 'add', 'and_', 'attrgetter', 'call', 'concat', 'contains', 'countOf', 
'delitem', 'eq', 'floordiv', 'ge', 'getitem', 'gt', 'iadd', 'iand', 'iconcat','ifloordiv', 'ilshift', 'imatmul', 'imod', 'imul', 'index', 'indexOf', 'inv', 
'invert', 'ior', 'ipow', 'irshift', 'is_', 'is_not', 'isub', 'itemgetter', 
'itruediv', 'ixor', 'le', 'length_hint', 'lshift', 'lt', 'matmul', 'methodcaller','mod', 'mul', 'ne', 'neg', 'not_', 'or_', 'pos', 'pow', 'rshift', 'setitem', 
'sub', 'truediv', 'truth', 'xor']

from operator import *

1、数学运算

注意:数字不可变。因此,原地运算符,会被计算,但不会被赋值,不改变原变量的数字。

函数对应运算符描述举例
add(a,b)a + b 相加add(2,3)  结果:5
iadd(a,b)a += b相加,原地运算符

a = 5

iadd(a,3)    结果:8
a     结果:5

sub(a,b)a - b 相减sub(2,3)  结果:-1
isub(a,b)a -= b相减,原地运算符
mul(a,b)a * b 相乘mul(2,3)  结果:6
imul(a,b)a *= b相乘,原地运算符
truediv(a,b)a / b 相除truediv(2,3)  结果:0.6666666666666666
itruediv(a,b)a /= b相除,原地运算符
floordiv(a,b)a // b 相除取整数floordiv(2,3)  结果:0
ifloordiv(a,b)a //= b相除取整数,原地运算符
mod(a,b)a % b 相除取余数mod(2,3)  结果:2
imod(a,b)a %= b相除取余数,原地运算符
pow(a,b)a ** b 幂,a^{b}pow(2,3)  结果:8
ipow(a,b)a **= b幂,原地运算符
matmul(a,b)a @ b 矩阵乘法
imatmul(a,b)a @= b矩阵乘法,原地运算符
neg(a)- a 算术取反neg(1)   结果:-1
pos(a)+ a 取正pos(-1)  结果:-1
abs(a)绝对值abs(-1)   结果:1
函数对应运算符描述举例
inv(a),  invert(a)按位取反,等价于 ~ a inv(2)   结果:-3
invert(2)   结果:-3
lshift(a,b)a << b 左移 lshift(2,3)  结果:16
ilshift(a,b)a <<= b左移,原地运算符
rshift(a,b)a >> b 右移rshift(2,3)  结果:0
irshift(a,b)a >>= b右移,原地运算符
and_(a,b)a & b 按位与 and_(2,3)   结果:2
iand(a,b)a &= b按位与,原地运算符
or_(a,b)a | b 按位或or_(2,3)   结果:3
ior(a,b)即 a |= b按位或,原地运算符
xor(a,b)a ^ b 按位异或xor(2,3)  结果:1
ixor(a,b)a ^= b按位异或,原地运算符

注解:(假设8位二进制,最高位为符号位,负数用补码形式存储)

① 按位取反。inv(2)   结果:-3

2(二进制:00000010):按位取反,则11111101(原码10000011,十进制:-3)。

② 左移。lshift(2,3)  结果:16

2(二进制:00000010):左移3位,则00010000(十进制:16)。

③ 按位与。and_(2,3)   结果:2

2(二进制:00000010),3(二进制:00000011):按位与,则00000010(十进制:2)。

按位与:1 & 1 = 1,1 & 0 = 0,0 & 0 = 0

按位或:1 | 1 = 1,1 | 0 = 1,0 | 0 = 0

按位异或:1 ^ 1 = 0,1 ^ 0 = 1,0 ^ 0 = 0

2、比较运算

函数对应运算符描述举例
lt(a,b)a < b 小于lt(2,3)   结果:True
le(a,b)a <= b 小于等于le(2,3)  结果:True
gt(a,b)a > b 大于gt(2,3)  结果:False
ge(a,b)a >= b 大于等于ge(2,3)  结果:False
eq(a,b)a == b 等于eq(2,3)   结果:False
ne(a,b)a  != b 不等于ne(2,3)  结果:True

lt:less than   小于

le:less than or equal to   小于等于

gt:greater than   大于

ge:greater than or equal to   大于等于

eq:equal to   等于

ne:not equal to   不等于​​​​​​​

3、逻辑运算

函数对应运算符描述举例
truth(a)a真值测试。a 为真,返回True,否则返回Falsetruth(0)  结果:False
not_(a)not a逻辑取反not_(0)  结果:True
is_(a,b)a is ba 是 b
is_not(a,b)a is not ba 不是 b

4、序列运算

注意:原地运算符中被赋值的序列需是可变的。若不可变的序列(字符串、元组),会计算但不会赋值,即不改变原序列。

函数对应运算符描述举例
concat(a,b)a + b 序列a、b,拼接concat([1],[2,3])  结果:[1, 2, 3]
iconcat(a,b)a += b序列a、b,拼接,原地运算符
contains(a,b)b in a序列a 中包含元素bcontains("hello","e")   结果:True
countOf(a,b)序列a 中元素b出现的次数countOf("hello","l")   结果:2
indexOf(a,b)序列a 中元素b第一次出现的位置。若不存在,则报错indexOf("hello","o")   结果:4
getitem(a,b)a[b] 序列a 中获取下标/切片b对应的元素getitem("hello",1)   结果:'e'
getitem("hello",slice(1,3))   结果:'el'
setitem(a,b,c)a[b]=c可变序列a 中赋值下标/切片b对应的元素为ca = [1,2,3]; setitem(a,2,"w"); a   结果:[1, 2, 'w']
a = [1,2,3]; setitem(a,slice(1,3),["w","y"]); a   结果:[1, 'w', 'y']
delitem(a,b)del a[b]可变序列a 中删除下标/切片b对应的元素a = [1,2,3]; delitem(a,1); a    结果:[1, 3]
a = [1,2,3]; delitem(a,slice(1,3)); a    结果:[1]
length_hint(a)len(a)序列a的长度length_hint("hello")    结果:5

add 和 iadd 也可以拼接序列,和concat结果相同。

函数对应运算符描述举例
add(a,b)a + b 序列a、b,拼接add([1],[2,3])   结果:[1, 2, 3]
iadd(a,b)a += b序列a、b,拼接,原地运算符

5、3.11 新版功能

提供了快速访问对象的属性、获取序列元素、方法调用。

适合作为快速提取器(map, sorted, itertools.groupby等)的参数。

(5-1)attrgetter  【访问对象的属性】

  • attrgetter(属性)(对象):对象.属性,即获取对象的属性。
  • attrgetter(属性1, 属性2 ...)(对象):(对象.属性1, 对象.属性2,...),即获取对象的多个属性,返回元组形式。
from operator import *class People(object):def __init__(self,name,age):self.name = nameself.age = agep1 = People("Tom",18)
p2 = People("Jack",25)get_age = attrgetter("age")
get_age(p1)                                   # 结果:18
get_age(p2)                                   # 结果:25
# 相当于         
p1.age                                        # 结果:18
p2.age                                        # 结果:25get_all = attrgetter("name","age")
get_all(p1)                                   # 结果:('Tom', 18)
get_all(p2)                                   # 结果:('Jack', 25)
# 相当于
p1.name,p1.age                                # 结果:('Tom', 18)
p2.name,p2.age                                # 结果:('Jack', 25)# attrgetter 比 lambda 速度快
list(map(get_age,[p1,p2]))                    # 结果:[18, 25]
# 相当于
list(map(lambda x:x.age,[p1,p2]))             # 结果:[18, 25]list(map(get_all,[p1,p2]))                    # 结果:[('Tom', 18), ('Jack', 25)]
# 相当于  
list(map(lambda x:(x.name,x.age),[p1,p2]))    # 结果:[('Tom', 18), ('Jack', 25)]

(5-2)itemgetter  【获取序列的元素】

  • itemgetter(下标)(序列) :序列[下标],即获取序列中下标对应的元素。
  • itemgetter(slice(起始下标, 结束下标))(序列):序列[起始下标:结束下标],通过切片获取序列中的元素。
  • itemgetter(下标1, 下标2, ...)(序列) :(序列[下标1],序列[下标2],...),即获取序列中多个下标对应的元素,返回元组形式。
from operator import *a = "hello"
itemgetter(1)(a)                  # 结果:'e'
itemgetter(slice(1,4))(a)         # 结果:'ell'
itemgetter(1,2,4)(a)              # 结果:('e', 'l', 'o')
  •  itemgetter(键)(字典) :字典[键],通过键获取字典中的值。
  •  itemgetter(键1, 键2,...)(字典) :(字典[键1], 字典[键2], ...),通过多个键获取字典中的值,返回元组形式。
from operator import *d = {'一季度':20,'二季度':50,'三季度':15,'四季度':35}
itemgetter('二季度')(d)                     # 结果:50
itemgetter('二季度','四季度')(d)            # 结果:(50, 35)

在sorted、map等使用时,itemgetter 比 lambda 速度快。

from operator import *b = [("一季度",20),("二季度",50),("三季度",15),("四季度",35)]
# 按元组中下标为1的元素大小排序
sorted(b,key=itemgetter(1))       # 结果:[('三季度', 15), ('一季度', 20), ('四季度', 35), ('二季度', 50)]
# 相当于
sorted(b,key=lambda x:x[1])       # 结果:[('三季度', 15), ('一季度', 20), ('四季度', 35), ('二季度', 50)]# 获取元组中下标为1的元素
list(map(itemgetter(1),b))        # 结果:[20, 50, 15, 35]
# 相当于
list(map(lambda x:x[1],b))        # 结果:[20, 50, 15, 35]

(5-3)methodcaller  【调用对象的方法】

  • methodcaller(方法)(对象):对象.方法(),即调用对象的方法。
  • methodcaller(方法, 参数1, 参数2 ...)(对象):对象.方法(参数1, 参数2,...),即调用对象的方法,并传递参数。
from operator import *class People(object):def __init__(self,name,age):self.name = nameself.age = agedef introduce(self):return f"我是{self.name}"p1 = People("Tom",18)intro = methodcaller("introduce")
intro(p1)                              # 结果:'我是Tom'
# 相当于
p1.introduce()                         # 结果:'我是Tom'

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/177848.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

windows下安装es及logstash、kibna

1、安装包下载 elasticsearch https://www.elastic.co/cn/downloads/past-releases#elasticsearch kibana安装包地址&#xff1a; https://www.elastic.co/cn/downloads/past-releases/kibana-8-10-4 logstash安装包地址&#xff1a; https://www.elastic.co/cn/downloads/past…

骨传导蓝牙耳机哪款好?这五款骨传导耳机闭眼入都不会错!

随着科技的发展&#xff0c;数码产品更新换代的速度也是越来越快&#xff0c;如今无线蓝牙耳机已经占据主流&#xff0c;特别是运动爱好者&#xff0c;很多人都会为自己挑选一款好用的运动耳机&#xff0c;而骨传导耳机异军突起&#xff0c;凭借听歌不入耳、佩戴舒适稳固等特性…

Postman如何发送Https请求

Postman如果想要发送Https请求&#xff0c;需要从设置中将SSL安全认证禁用

ubuntu中使用 vscode 连接docker开发环境

文章目录 ubuntu中使用 vscode 连接docker开发环境步骤一&#xff1a;安装 Remote Development 插件步骤二&#xff1a;连接远程环境步骤三&#xff1a;开发 问题解决参考连接 ubuntu中使用 vscode 连接docker开发环境 Remote Development 是一个 Visual Studio Code 插件&…

FPGA时序约束与分析-简单入门

FPGA时序约束与分析-简单入门 文章目录 FPGA时序约束与分析-简单入门1. 本课程概述2. 时序约束简介2.1 什么是时序约束2.2 合理的时序约束2.3 *基于Vivado的时序约束方法 3. 时序分析的基本概念3.1 时钟与时钟偏差3.2 建立时间和保持时间3.3 时序分析中路径、沿和关系的定义 4.…

数据中心:精密空调监控,这招太高效了!

在当今日益复杂的工业环境中&#xff0c;精密空调系统的监控和管理变得至关重要。随着科技的迅猛发展&#xff0c;各行各业对温度、湿度和空气质量等参数的高度控制需求不断增加。 精密空调监控系统通过实时数据采集、分析和反馈&#xff0c;为企业提供了可靠的手段来确保生产环…

C++异常处理:如何使用try、catch、throw

一、概述 在C中&#xff0c;异常处理是一种重要的编程技术&#xff0c;用于处理程序运行过程中可能出现的意外情况。异常处理通过使用try、catch和throw关键字来实现。这些关键字共同协作&#xff0c;帮助程序员在发生错误时&#xff0c;更好地控制程序的流程&#xff0c;并优…

2017年计网408

第33题 假设 OSI 参考模型的应用层欲发送 400B 的数据 (无拆分), 除物理层和应用层之外, 其他各层在封装 PDU 时均引入 20 B 的额外开销, 则应用层数据传输效率约为( )A. 80%B. 83%C. 87%D. 91% 本题考察有关数据包逐层封装的相关概念。我们来一起分析一下。 这是要求大家必须…

数据结构:AVLTree的插入和删除的实现

个人主页 &#xff1a; 个人主页 个人专栏 &#xff1a; 《数据结构》 《C语言》《C》 文章目录 前言一、AVLTree二、AVLTree的插入插入新增节点调整平衡因子旋转左单旋(新增节点位于较高右子树的右侧)右单旋(新增节点位于较高左子树的左侧)右左双旋(新增节点在较高右子树的左子…

考研分享第3期 | 211本378分上岸大连理工电子信息经验贴

考研分享第3期 | 211本378分上岸大连理工电子信息经验贴 一、个人信息 姓名&#xff1a;Ming 本科院校&#xff1a;某211学校电子信息工程学院 电子科学与技术专业 上岸院校&#xff1a;大连理工大学 电子信息与电气工程学部 电子信息&#xff08;0854&#xff09; 择校意…

java springBoot实现RabbitMq消息队列 生产者,消费者

1.RabbitMq的数据源配置文件 # 数据源配置 spring:rabbitmq:host: 127.0.0.1port: 5672username: rootpassword: root#消息发送和接收确认publisher-confirms: truepublisher-returns: truelistener:direct:acknowledge-mode: manualsimple:acknowledge-mode: manualretry:ena…

【JavaEE】Servlet API 详解(HttpServletResponse类方法演示、实现自动刷新、实现自动重定向)

一、HttpServletResponse HttpServletResponse表示一个HTTP响应 Servlet 中的 doXXX 方法的目的就是根据请求计算得到相应, 然后把响应的数据设置到 HttpServletResponse 对象中 然后 Tomcat 就会把这个 HttpServletResponse 对象按照 HTTP 协议的格式, 转成一个字符串, 并通…