• 零基础学python-9.3 对象的比较


    1.所有的python对象都可以支持比较操作-测试相等性、相对大小等

    python的比较是检查复合对象的所有部分,直到得出结果,它会自动遍历数据结构,从左到右递归比较,有多深走多深。

    >>> L1=[1,('a',4)]
    >>> L2=[1,('a',4)]
    >>> L1==L2,L1 is L2
    (True, False)
    >>> 
    ==:对比值

    is:对比内存引用

    上面的例子,虽然两个列表的值是相等的,但是它们是不同的对象,存储在不同的内存区域当中,引用不同的内存地址,所以==操作相同,is操作不同

    再来看两个例子(注意:下面我们将是两个字符串的例子,在python中,无论多长的没有空格的字符组合都算短字符,如果字符串中间出现空格,那么他就是长字符串)

    >>> str1='abc'
    >>> str2='abc'
    >>> str1==str2,str1 is str2
    (True, True)
    >>> str1='abcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmn'
    >>> str2='abcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmn'
    >>> str1==str2,str1 is str2
    (True, True)

    python对于短字符采取缓存机制,所以无论是==操作还是is操作都返回true

    下面的例子跟上面的字符是一样的,只不过在字符中间随机插入空格,然后python就当他是长字符串

    >>> str1='a b c'
    >>> str2='a b c'
    >>> str1==str2,str1 is str2
    (True, False)
    >>> 
    >>> str1='abcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmn'
    >>> str2='abcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmnabcefghijklmn'
    >>> str1==str2,str1 is str2
    (True, True)

    对于长字符串没有缓存机制,所以==返回true,因为值相等,而is操作返回false,内存地址不同

    类似的还有数字类型

    对于小的整形,python还是使用了缓存机制,其他则不是

    >>> int1=1
    >>> int2=1
    >>> int1==int2,int1 is int2
    (True, True)
    >>> int1=1000
    >>> int2=1000
    >>> int1==int2,int1 is int2
    (True, False)

    >>> float1=1.2
    >>> float2=1.2
    >>> float1==float2 ,float1 is float2
    (True, False)
    >>> 

    2.字典的比较

    在python3之前的版本,字典是可以比较大小的,但是在3.0之后取消了这一个

    >>> d1={'a':1,'b':2}
    >>> d2={'a':1,'b':2}
    >>> d1==d2,d1 is d2
    (True, False)
    >>> d1<d2
    Traceback (most recent call last):
      File "<pyshell#34>", line 1, in <module>
        d1<d2
    TypeError: unorderable types: dict() < dict()
    >>> 

    需要对比大小,就需要把字典变成list或者使用sorted的内置函数

    >>> d1={'a':1,'b':2}
    >>> d2={'a':1,'b':3}
    >>> list(d1.items ())
    [('b', 2), ('a', 1)]
    >>> sorted(d1.items ())
    [('a', 1), ('b', 2)]
    >>> sorted(d1.items ())<sorted(d2.items ())
    True
    >>> 



    就说到这里,谢谢大家

    ------------------------------------------------------------------

    点击跳转零基础学python-目录




    版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 相关阅读:
    Scala依赖注入
    Scala实现树形结构
    Spark GraphX快速入门
    mysql服务自启【Linux】
    Centos7安装mysql5.6
    Scala路径依赖【内部类】
    spark查看DF的partition数目及每个partition中的数据量【集群模式】
    Python自定义异常及抛出异常
    Spark应用【根据新df更新旧df】
    Linux安装JDK
  • 原文地址:https://www.cnblogs.com/raylee2007/p/4774467.html
Copyright © 2020-2023  润新知