zoukankan      html  css  js  c++  java
  • 比较python类的两个instance(对象) 是否相等

    http://www.yihaomen.com/article/python/281.htm

    比较python类的两个instance(对象) 是否相等

    对于同一个Class,可以创建不同的实例(instance), 如何比较这两个 instance 是否相等呢?我们知道,对于计算机来说,要判断两个对象是否相等,就是看在内存中的地址是否同一个。如果内存地址一样,那么肯定是相等的。这种情况通常出现在一个对象是另外一个对象的引用时出现。
    但在实际的开发过程中,要比较两个对象是否相等,并不是通过内存地址来判断的,而是通过这两个对象的部分属性值,或者全部属性值来对比判断的。
    假设有一个职员Class, 我们分别创建了两个对象
    程序代码 程序代码

    class Staff(object):
        def __init__(self,id,name,sex):
            self.id=id
            self.name=name
            self.sex=sex

    我们这样认为,如果id 相同,则表示两个对象相等,id姑且表示身份证编号吧,如果身份证编号相同,那么肯定是同一人,在实际的项目中会遇到这样的情况。
    创建对象并查看各自的内存地址
    程序代码 程序代码

    staff1=Staff("123456","张三","男")
    staff2=Staff("123456","李四","女")
    print id(staff1),id(staff2)
    #12327248 12327184

    结果很明显,在不同的内存地址,这时候如果判断 staff1==staff2 ,结果肯定是  False。

    如何满足我们的需要,只要id 相同的对象,就认为是相等的对象呢,有如下几种方法:
    一.重载 Staff Class 的 __eq__ 方法
    程序代码 程序代码

    class Staff(object):
        def __init__(self,id,name,sex):
            self.id=id
            self.name=name
            self.sex=sex
            
        def __eq__(self,other):
            return self.id==other.id 

    staff1=Staff("123456","张三","男")
    staff2=Staff("123456","李四","女")
    print id(staff1),id(staff2)
    print staff1==staff2
    #True

    结果返回为 true,说明是相等的,但在计算机中的内存地址,肯定是不一样的。这里重载了__eq__方法,当然你还可以 增加比较条件,例子中只对比了id. 用同样的方法,还可以实现 两个对象相加等操作,重载__add__ 方法。

    2.直接属性值对比来实现
    程序代码 程序代码

    staff1=Staff("123456","张三","男")
    staff2=Staff("123456","李四","女")
    print id(staff1),id(staff2)
        
    print staff1.__dict__
    print staff2.__dict__
        
    if staff1.__dict__['id']==staff2.__dict__['id']:
          print 'yes,equal'

    你会发现,这样也是可以的,同样也可以对比多个属性,这里的重点是用到了python Class 的 __dict__系统内置方法来实现。 
  • 相关阅读:
    python Exception中的raise、assert
    python循环语句与其他编程语言不同之处
    【转】最大似然估计
    尝试发表代码
    奇异分解(SVD)
    Python学习笔记3-string
    梯度下降法
    前后端分离
    Trie树
    HashMap的工作原理以及代码实现,为什么要转换成红黑树?
  • 原文地址:https://www.cnblogs.com/saolv/p/9839626.html
Copyright © 2011-2022 走看看