zoukankan      html  css  js  c++  java
  • python基础-集合类型

    # 1、作用
    # 1.1 关系运算
    # friends1 = ["zero","kevin","jason","egon"]
    # friends2 = ["Jy","ricky","jason","egon"]
    #
    # l=[]
    # for x in friends1:
    #     if x in friends2:
    #         l.append(x)
    # print(l)
    
    
    # 1.2、去重
    
    
    # 2、定义: 在{}内用逗号分隔开多个元素,多个元素满足以下三个条件
    #            1. 集合内元素必须为不可变类型
    #            2. 集合内元素无序
    #            3. 集合内元素没有重复
    
    s = {1,2,3,4}  # 本质 s = set({1,2,3,4})
    
    # 注意1:列表类型是索引对应值,字典是key对应值,均可以取得单个指定的值,而集合类型既没有索引也没有key与值对应,所以无法取得单个的值,而且对于集合来说,主要用于去重与关系元素,根本没有取出单个指定值这种需求。
    
    # 注意2:{}既可以用于定义dict,也可以用于定义集合,但是字典内的元素必须是key:value的格式,现在我们想定义一个空字典和空集合,该如何准确去定义两者?
    d = {} # 默认是空字典 
    s = set() # 这才是定义空集合
    # s={1,2} # s=set({1,2})
    
    # s={1,[1,2]} # 集合内元素必须为不可变类型
    # s={1,'a','z','b',4,7} # 集合内元素无序
    # s={1,1,1,1,1,1,'a','b'} # 集合内元素没有重复
    # print(s)
    
    # 了解
    # s={} # 默认是空字典
    # print(type(s))
    # 定义空集合
    # s=set()
    # print(s,type(s))
    
    # 3、类型转换
    # set({1,2,3})
    # res=set('hellolllll')
    # print(res)
    
    # print(set([1,1,1,1,1,1]))
    # print(set([1,1,1,1,1,1,[11,222]]) # 报错
    
    # print(set({'k1':1,'k2':2}))
    # 但凡能被for循环的遍历的数据类型(强调:遍历出的每一个值都必须为不可变类型)都可以传给set()转换成集合类型
    >>> s = set([1,2,3,4])
    >>> s1 = set((1,2,3,4))
    >>> s2 = set({'name':'jason',})
    >>> s3 = set('egon')
    >>> s,s1,s2,s3
    {1, 2, 3, 4} {1, 2, 3, 4} {'name'} {'e', 'o', 'g', 'n'}
    # 4、内置方法
    # =========================关系运算符=========================
    friends1 = {"zero","kevin","jason","egon"}
    friends2 = {"Jy","ricky","jason","egon"}
    
    # 4.1 取交集:两者共同的好友
    # res=friends1 & friends2
    # print(res)
    # print(friends1.intersection(friends2))
    # 4.2 取并集/合集:两者所有的好友
    # print(friends1 | friends2)
    # print(friends1.union(friends2))
    
    # 4.3 取差集:取friends1独有的好友
    # print(friends1 - friends2)
    # print(friends1.difference(friends2))
    
    # 取friends2独有的好友
    # print(friends2 - friends1)
    # print(friends2.difference(friends1))
    
    # 4.4 对称差集: 求两个用户独有的好友们(即去掉共有的好友)
    # print(friends1 ^ friends2)
    # print(friends1.symmetric_difference(friends2))
    
    # 4.5 父子集:包含的关系
    # s1={1,2,3}
    # s2={1,2,4}
    # 不存在包含关系,下面比较均为False
    # print(s1 > s2)
    # print(s1 < s2)
    
    # s1={1,2,3}
    # s2={1,2}
    # print(s1 > s2) # 当s1大于或等于s2时,才能说是s1是s2他爹
    # print(s1.issuperset(s2))
    # print(s2.issubset(s1)) # s2 < s2  =>True
    
    # s1={1,2,3}
    # s2={1,2,3}
    # print(s1 == s2) # s1与s2互为父子
    # print(s1.issuperset(s2))
    # print(s2.issuperset(s1))
    
    
    # =========================去重=========================
    # 1、只能针对不可变类型去重
    # print(set([1,1,1,1,2]))
    
    # 2、无法保证原来的顺序
    # l=[1,'a','b','z',1,1,1,2]
    # l=list(set(l))
    # print(l)
    
    
    l=[
        {'name':'lili','age':18,'sex':'male'},
        {'name':'jack','age':73,'sex':'male'},
        {'name':'tom','age':20,'sex':'female'},
        {'name':'lili','age':18,'sex':'male'},
        {'name':'lili','age':18,'sex':'male'},
    ]
    new_l=[]
    for dic in l:
        if dic not in new_l:
            new_l.append(dic)
    
    # print(new_l)
    
    # 其他操作
    '''
    # 1.长度
    >>> s={'a','b','c'}
    >>> len(s)
    3
    
    # 2.成员运算
    >>> 'c' in s
    True
    
    # 3.循环
    >>> for item in s:
    ...     print(item)
    ... 
    c
    a
    b
    '''
    
    # 其他内置方法
    s={1,2,3}
    # 需要掌握的内置方法1:discard
    # s.discard(4) # 删除元素不存在do nothing
    # print(s)
    # s.remove(4) # 删除元素不存在则报错
    
    
    # 需要掌握的内置方法2:update
    # s.update({1,3,5})
    # print(s)
    
    # 需要掌握的内置方法3:pop
    # res=s.pop()
    # print(res)
    
    # 需要掌握的内置方法4:add
    # s.add(4)
    # print(s)
    
    
    
    # 其余方法全为了解
    res=s.isdisjoint({3,4,5,6}) # 两个集合完全独立、没有共同部分,返回True
    print(res)
    
    # 了解
    # s.difference_update({3,4,5}) # s=s.difference({3,4,5})
    # print(s)
    每天学习新的知识,会让自己更加充实
  • 相关阅读:
    HDoj-2072-字数
    hibou 主界面自己侧滑的定义
    Android得到一个闹钟在第三方
    UILabel,UITextField 以及UIButton应用
    推荐几个好文章
    半年后,我还在路上。
    NGUI 3.5过程(三)Button button
    OpenGL研究2.0 计算圆
    CF 444A(DZY Loves Physics-低密度脂蛋白诱导子图)
    美日高价进口中国非转基因大豆:不仅吃还做药
  • 原文地址:https://www.cnblogs.com/fengpiaoluoye/p/14086694.html
Copyright © 2011-2022 走看看