Python中operator模块的操作

2023-11-17

Operator模块提供了一系列与Python自带操作一样有效的函数。例如:operator.add(x, y)和表达式x+y是等效的。那些特殊类的方法都有自己的函数名;为了方便起见,一些函数名是没有前导和后置(__)。 在接下来讨论的函数涉及对象比较,逻辑运算,数学运算,队列操作和抽象类型测试。对象比较函数对所有对象都适用,并且都以他们所支持的丰富的比较操作而命名。operator模块是用c实现的,所以执行速度比python代码快。

逻辑操作

逻辑操作一般来说也可以应用在所有的,不同类型的值(value)上, 同时支持真值检验, 等式检验, 布尔操作:

from operator import *

a = [1, 2, 3]
b = a
print 'a =', a
print 'b =', b
print

print 'not_(a):', not_(a)
print 'truth(a):', truth(a) #对象是否是真的
print 'is_(a, b):', is_(a, b) # 检验对象是否相等
print 'is_not(a, b) :', is_not(a, b)

运行结果:

a = [1, 2, 3]
b = [1, 2, 3]

not_(a): False
truth(a): True
is_(a, b): True
is_not(a, b) : False
比较操作
from operator import *
a = 3
b = 5
for func in [lt, le, eq, ne, ge, gt]:
    print '{0}(a, b):'.format(func.__name__), func(a, b)

结果:

lt(a, b): True    #等价于a<b 
le(a, b): True    #等价于a<=b
eq(a, b): False   #等价于a==b  
ne(a, b): True    #等价于a!=b
ge(a, b): False    #等价于a>=b
gt(a, b): False    #等价于a>b  

其中’{0}(a, b):’.format(func.__name__)得到的如上所示,也是一种很方便的写法

算术操作符
from operator import *
a, b, c, d = -1, 2, -3, 4

print 'a =', a
print 'b =', b
print 'c =', c
print 'd =', d

print '\nPositive/Negative:'
print 'abs(a):', abs(a)
print 'neg(a):', neg(a)
print 'neg(b):', neg(b)
print 'pos(a):', pos(a)
print 'pos(b):', pos(b)

结果:

a = -1
b = 2
c = -3
d = 4

Positive/Negative:
abs(a): 1
neg(a): 1
neg(b): -2
pos(a): -1
pos(b): 2

abs返回值得绝对值,neg返回(-obj), pos返回(+obj)。

a = -2
b = 5.0

print 'a =', a
print 'b =', b

print '\nArithmetic'
print 'add(a, b)    :', add(a, b)
print 'div(a, b)    :', div(a, b)
print 'floordiv(a, b)  :', floordiv(a, b)
print 'mod(a, b)    :', mod(a, b)
print 'mul(a, b)    :', mul(a, b)
print 'pow(a, b)    :', pow(a, b)
print 'sub(a, b)    :', sub(a, b)
print 'truediv(a, b)  :', truediv(a, b)

结果:

a = -2
b = 5.0

Arithmetic
add(a, b)    : 3.0  # 返回 a+ b
div(a, b)    : -0.4 # 返回 a/ b
floordiv(a, b)  : -1.0 # 返回 a// b
mod(a, b)    : 3.0
mul(a, b)    : -10.0
pow(a, b)    : -32.0
sub(a, b)    : -7.0
truediv(a, b)  : -0.4

mod表示取模, mul 表示相乘,pow是次方, sub表示相减

关于python运算符

a = 2
b = 6

print 'a =', a
print 'b =', b

print '\nBitwise:'
print 'and_(a, b)  :', and_(a, b)
print 'invert(a)  :', invert(a)
print 'lshift(a, b) :', lshift(a, b)
print 'or_(a, b)  :', or_(a, b)
print 'rshift(a, b) :', rshift(a, b)
print 'xor(a, b)  :', xor(a, b)

结果:

a = 2
b = 6

Bitwise:
and_(a, b)  : 2
invert(a)  : -3
lshift(a, b) : 128
or_(a, b)  : 6
rshift(a, b) : 0
xor(a, b)  : 4

其中:and 表示按位与, invert 表示取反操作, lshift表示左位移, or表示按位或, rshift表示右位移,xor表示按位异或。

原地操作符

即in-place操作, x += y 等同于 x = iadd(x, y), 如果复制给其他变量比如z = iadd(x, y)等同与z = x; z += y

print '\nIn-place operator'
a = 3
b = 4
c = [1, 2]
d = ['a', 'b']

print 'a =', a
print 'b =', b
print 'c =', c
print 'd =', d
print

a = iadd(a, b)
print 'a = iadd(a, b) =>', a
print

c = iconcat(c, d)
print 'c = iconcat(c, d) =>', c

结果:

In-place operator
a = 3
b = 4
c = [1, 2]
d = ['a', 'b']

a = iadd(a, b) => 7

c = iconcat(c, d) => [1, 2, 'a', 'b']
属性和元素的获取方法

属性获取方法类似于 lambda x, n=’attrname’:getattr(x,n)

print 'The attributes and elements of the collection method'

class MyObj(object):

    def __init__(self, arg):
        super(MyObj, self).__init__()
        self.arg = arg
    def __repr__(self):
        return 'MyObj(%s)' % self.arg
# 列表推导式非常方便
objs = [MyObj(i) for i in xrange(5)]
print "Object:", objs
#获取属性值 
g = attrgetter("arg") # 属性获取
vals = [g(i) for i in objs] #g(i)得到属性为arg的对象的属性值
print "arg values:", vals

objs.reverse() # 列表反转
print "reversed:", objs
print "sorted:", sorted(objs, key=g) # 排序,按key排序,在此为属性值排序,默认为升序

结果:

The attributes and elements of the collection method
Object: [MyObj(0), MyObj(1), MyObj(2), MyObj(3), MyObj(4)]
arg values: [0, 1, 2, 3, 4]
reversed: [MyObj(4), MyObj(3), MyObj(2), MyObj(1), MyObj(0)]
sorted: [MyObj(0), MyObj(1), MyObj(2), MyObj(3), MyObj(4)]

元素获取方法类似于:lambda x,y=5:x[y],除了序列之外,元素获取方法还适用于映射

l = [dict(val=-1*i) for i in xrange(4)] # 得到字典“val”作为key
print "dictionaries:", l
g = itemgetter("val")  # 元素获取
vals = [g(i) for i in l]
print "values: ", vals
print "sorted:", sorted(l, key=g) # 按照元素排序

l = [(i,i*-2) for i in xrange(4)] # 得到元组
print "tuples: ", l
g = itemgetter(1) # 得到l的第一域的值,对比字典:是键对应的值
vals = [g(i) for i in l]
print "values:", vals
print "sorted:", sorted(l, key=g) # 按照元组第一域排序

结果:

dictionaries: [{'val': 0}, {'val': -1}, {'val': -2}, {'val': -3}]
values:  [0, -1, -2, -3]
sorted: [{'val': -3}, {'val': -2}, {'val': -1}, {'val': 0}]
tuples:  [(0, 0), (1, -2), (2, -4), (3, -6)]
values: [0, -2, -4, -6]
sorted: [(3, -6), (2, -4), (1, -2), (0, 0)]
结合操作符和定制类

operator模块中的函数通过相应操作的标准Python接口完成工作,所以它们不仅适用于内置类型,还适用于用户自定义类型。

from operator import *

class MyObj(object):

  def __init__(self, val):
    super(MyObj, self).__init__()
    self.val = val

  def __str__(self):
    return "MyObj(%s)" % self.val

  def __lt__(self, other): # 用户自定义lt的形式
    return self.val < other.val

  def __add__(self, other): # 用户自定义add的输出形式
    return MyObj(self.val + other.val)

a = MyObj(1)
b = MyObj(2)
print lt(a, b)
print add(a,b)

结果:

True
MyObj(3) # 自定义的形式
类型检查

operator 模块还包含一些函数用来测试映射、数字和序列类型的API兼容性

class NoType(object):
    pass

class MultiType(object):

    def __len__(self):
        return 0

    def __getitem__(self, name):
        return "mapping"

    def __int__(self):
        return 0

o = NoType()
t = MultiType()

for func in [isMappingType, isNumberType, isSequenceType]:
    print "%s(o):" % func.__name__, func(o)
    print "%s(t):" % func.__name__, func(t)

结果:

isMappingType(o): False
isMappingType(t): True
isNumberType(o): False
isNumberType(t): True
isSequenceType(o): False
isSequenceType(t): True
获取对象方法
class Student(object):

    def __init__(self, name):
        self.name = name

    def getName(self):
        return self.name

stu = Student("Jim")
func = methodcaller('getName') # 使用methodcaller可以获取对象的方法。
print func(stu)  # 获取对象的方法

结果:

Jim

附加range和xrange的区别:

>>> range(5)  # 生成的是一个数组
[0, 1, 2, 3, 4]
>>> range(1,5)
[1, 2, 3, 4]
>>> range(0,6,2)
[0, 2, 4]
>>> xrange(5)
xrange(5)
>>> list(xrange(5))  # 生成的是一个生成器
[0, 1, 2, 3, 4]
>>> for i in range(0, 5):  
    print i

0
1
2
3
4
>>> for i in xrange(0, 5):  # 结果和range完全相同,但本质是不同的
    print i

0
1
2
3
4
>>> type(range(1,10))  # 类型不同
<type 'list'>
>>> type(xrange(1,10))
<type 'xrange'>
>>> 

所以xrange做循环的性能比range好,尤其是返回很大的时候

参考:

http://www.jb51.net/article/87550.htm

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Python中operator模块的操作 的相关文章

随机推荐

  • Eureka与Zookeeper的区别

    著名的CAP 理论指出 一个分布式系统不可能同时满足 C 一致性 A 可用性 和 P 分区容错性 由于分区容错性在是分布式系统中必须要保证的 因此我们只能在 A 和 C 之间进行权衡 在此 Zookeeper 保证的是 CP 而 Eurek
  • mysql数据库中的索引有那些、有什么用

    转载http www 2cto com database 201212 173288 html mysql 数据库中的索引有那些 有什么用 本文主要讲述了如何加速动态网站的MySQL索引分析和优化 www 2cto com 一 什么是索引
  • Rocksdb 代码学习 写流程1(WriteBatch写,WriterThead调度Writer)

    1 几个需要使用的相关类 1 Slice 主要用来装数据的 就两个成员变量data size 就是用装key和value的值 长度 以及一些处理函数 class Slice public Create an empty slice Slic
  • 文件上传到s3服务器,如何将文件从远程服务器传输到我的Amazon S3实例?

    1 带密钥的SSH sh keygen f ssh id rsa q P cat ssh id rsa pub 将此SSH密钥放入 ssh authorized keys文件 mkdir ssh chmod 0700 ssh touch s
  • spring事务(注解 @Transactional )失效的12种场景

    文章目录 一 事务不生效 七种 1 访问权限问题 只有public方法会生效 2 方法用final修饰 不会生效 3 同一个类中的方法直接内部调用 会导致事务失效 3 1 新加一个Service方法 3 2 在该Service类中注入自己
  • WPS显示无法创建对象,请确认对象已在系统注册表中注册

    写论文想插公式发现没法插入了 注册表又不知道改哪个 所以干脆 1 卸载WPS 不保留信息 2 选择另一个不同的路径重新安装即可
  • java中的数据加密

    记录 一 java中的数据加密 Java提供的安全模型和API 加密基础知识 使用JAVA实现加密 二 Java提供的安全模型和API 2 1 Java语言本身的安全性 自动内存管理 对于生成的对象在生命周期结束后会自动销毁 自动数组溢出检
  • matlab for循环坑

    matlab 用 for 嵌套循环遍历数组时 可能有 bug matlab octave 环境 linux Matlab R2018a 1 windows GNU Octave version 5 2 0 以 for x vector 的形
  • 遍历-字典里面取键

    输入字符串 输出为 字典 输入字符串 并统计字符串重叠单个次数 a 小明456fgdddhhh55adbyjjjjj m for ch in a 从a字符串里面取值 if ch in m 取出来的值如果在 m 里面 m ch 1 m字典里面
  • 词云制作(中文分词+英文)

    英文文本制作词云图 pip install wordcloud filename XX txt 将目标文本文件放入这里 with open filename encoding utf8 as f mytext f read mytext 查
  • 教程:Word中如何让参考文献编号和引用标记都是数字上标

    教程 Word中如何让参考文献编号和引用标记都是上标 更新历史 20190509 首次发布 使用Microsoft Word写论文之类的文档的时候 经常需要列出参考文献 并对它们进行引用 有时候 格式规范要求我们将参考文献编号和引用标记都变
  • vscode 注释

    这篇文章主要介绍了vscode添加注释的方法 具有一定借鉴价值 需要的朋友可以参考下 希望大家阅读完这篇文章后大有收获 下面让小编带着大家一起了解一下 1 在 Vscode 扩展商店中搜索koroFileHeader 点击安装 2 注释模板
  • 计算机视觉应该怎样入门?

    知乎问答 计算机视觉应该怎样入门 目录 第一阶段 技术基石 图像处理基础 图像处理进阶 第二阶段 深度学习 神经网络初步与调参技巧 深度卷积神经网络原理与实践 图像搜索技术 大规模车辆图片搜索 重识别 第三阶段 重点攻坚 目标检测及其在无人
  • socket 编程

    为什么80 的码农都做不了架构师 gt gt gt 利用windows api进行最原始的socket编程 服务端 WSAStartup ListenSock socket bind listen ListenSock acceptSock
  • 实战3-淘宝用户行为分析及可视化

    淘宝用户行为分析及可视化 目录 淘宝用户行为分析及可视化 分析背景 明确问题 读取和理解数据 数据预处理 数据分析与可视化 用户行为分析 日PV和日UV PV与UV相关性 可视化 时PV和时UV 相关性 可视化 不同行为类型用户PV分析 操
  • stata协整检验结果怎么看_面板数据协整检验

    5 3 1裴德劳因 Pedroin 检验 裴德劳因 Pedroin 1999 提出了以恩格尔 Engle 和格兰杰 Granger 二步法为基础的面板数据的协整检验方法 该方法利用协整方程的回归残差构造了七个统计量来检验面板数据之间的协整关
  • vue 引入高德地图 amap 报错:jsapi 不生效 INVALID_USER_SCODE

    高德地图 JSAPI key 和安全密钥的使用 自2021年12月02日升级 升级之后所申请的 key 必须配备安全密钥 jscode 一起使用 报错 高德地图jsapi不生效 INVALID USER SCODE 是因为没有设置安全密钥
  • 全排列

    举例 123的全排列 123 132 213 231 321 312 全排列的个数为 n STL 实现 char s 50 cin gt gt s int k strlen s sort s s k cout lt
  • IDEA中Sprint MVC环境配置<mvc:default-servlet-handler/>报错

    问题描述 在配置applicationContext xml文件时 mvc default servlet handler 出现问题不能正常使用 提示未声明 但是mvc其他的都可以正常使用 比如 mvc annotation driven
  • Python中operator模块的操作

    Operator模块提供了一系列与Python自带操作一样有效的函数 例如 operator add x y 和表达式x y是等效的 那些特殊类的方法都有自己的函数名 为了方便起见 一些函数名是没有前导和后置 在接下来讨论的函数涉及对象比较