码迷,mamicode.com
首页 > 编程语言 > 详细

Python记录3:集合

时间:2018-12-05 02:12:37      阅读:290      评论:0      收藏:0      [点我收藏+]

标签:lex   pen   list   不可   style   linu   super   int   局限   

#一,集合类型
###找出两个集合的交集并将结果打印出来
# python_stu=[‘egon‘,‘alex‘,‘kevin‘,‘王大炮‘,‘李二丫‘]
# linux_stu=[‘张铁蛋‘,‘刘铜蛋‘,‘赵金蛋‘,‘alex‘,‘kevin‘,‘oldboy‘]
# res=[]
# for stu1 in python_stu:
# if stu1 in linux_stu:
# res.append(stu1)
# print(res)
#
#2 集合
# 定义方式:在{}用逗号分割开多个元素,但是集合内元素必须要满足一下特点
#2.1: 必须是不可变类型
#2.2: 不能重复
#2.3: 集合内元素无序
# s={1,1,1,1,1,1} #s=set({1,1,1,1,1,1})
# print(s)
# print(type(s))

# s1=set(‘hello‘)
# print(s1)
# print(type(s1))

# s={}
# print(type(s))
#这样定义一个空的,打印出来的是一个字典
#要定义一个集合必须这样定义
# s=set()
# print(s,type(s))

# s={‘egon‘,‘alex‘,‘kevin‘,‘oldboy‘}
# print(s,type(s))

# 3、常用操作+内置的方法
#优先掌握的操作:(*****)
#1、长度len
# s={‘egon‘,‘alex‘,‘kevin‘,‘oldboy‘}
# print(len(s))
#2、成员运算in和not in
# s={‘egon‘,‘alex‘,‘kevin‘,‘oldboy‘}
# print(‘egon‘ in s)

# python_stu={‘egon‘,‘alex‘,‘kevin‘,‘王大炮‘,‘李二丫‘}
# for item in python_stu:
# print(item)
# linux_stu={‘张铁蛋‘,‘刘铜蛋‘,‘赵金蛋‘,‘alex‘,‘kevin‘,‘oldboy‘}
#3、|合集:取两个集合合并后的结果,例如:取老男孩所有报名的学生姓名
# print(python_stu | linux_stu)
# print(python_stu.union(linux_stu))

# python_stu=python_stu.union(linux_stu)
# python_stu.update(linux_stu)
# print(python_stu)

#4、&交集: 取两个集合共同的部分,例如:取同时报名两门课程的学员
# print(python_stu & linux_stu)
# print(python_stu.intersection(linux_stu))
# python_stu.intersection_update(linux_stu) #python_stu=python_stu.intersection(linux_stu)
# print(python_stu)

#5、-差集: 取存在于左边结合但不存在与右面集合的元素,例如:取只报名python课程的学员
# print(python_stu - linux_stu)
# print(python_stu.difference(linux_stu))

#6、^对称差集:例如:取没有同时报名两门课程的学员
# print((python_stu - linux_stu) | (linux_stu - python_stu))
# print(python_stu ^ linux_stu)
# print(python_stu.symmetric_difference(linux_stu))

#7、==判断是否相等,集合中只要元素相等,集合就相等,集合是无序的
# s1={1,2,3}
# s2={3,2,1}
# print(s1 == s2)

#8、父集:>= print(s1.issuperset(s2))
#9、子集:<= print(s2.issubset(s1))
# s1={1,2,3,4}
# s2={1,2,3}
# print(s1 >= s2)
# print(s1.issuperset(s2))
# print(s2.issubset(s1))

# 集合類型其他内置方法(**)
##pop 从最后面弹出来 一个一个按照顺序弹出来
# s1={‘a‘,‘b‘,‘c‘}
# print(s1.pop())
# print(s1)
# print(s1.pop())
# print(s1)
# print(s1.pop())
# print(s1)

# res=s1.remove(‘b‘)
# print(s1)
# print(res)
# s1.remove(‘d‘)
# s1.discard(‘d‘)
# print(s1)

# s1.add(‘d‘)
# print(s1)

# s1={1,2,3}
# s2={6,4,5}
# print(s1.isdisjoint(s2))
#判断两个集合是否有交集
# ======================================该类型总结====================================
# 集合是存多个值的
# 无序的
# 可变类型(1、可变:值变,id不变。可变==不可hash 2、不可变:值变,id就变。不可变==可hash)

# s1={1,2,3}
# print(id(s1))
# s1.update({4,5,6})
# print(s1)
# print(id(s1))

# 去重:
# stus=[‘egon‘,‘egon‘,‘egon‘,‘kevin‘,1,2,3,‘alex‘]
# res=set(stus)
# print(list(res))

#去重的局限性:
#1. 被去重的元素必須是不可变类型
#2. 不能保证原来的顺序

# l=[
# {‘name‘:‘egon‘,‘age‘:18,‘sex‘:‘male‘},
# {‘name‘:‘alex‘,‘age‘:73,‘sex‘:‘male‘},
# {‘name‘:‘kevin‘,‘age‘:20,‘sex‘:‘female‘},
# {‘name‘:‘egon‘,‘age‘:18,‘sex‘:‘male‘},
# {‘name‘:‘egon‘,‘age‘:18,‘sex‘:‘male‘},
# ]
# # print({‘name‘:‘egon‘,‘age‘:18,‘sex‘:‘male‘} in l)
# l1=[]
# for dic in l:
# if dic not in l1:
# l1.append(dic)
# print(l1)

Python记录3:集合

标签:lex   pen   list   不可   style   linu   super   int   局限   

原文地址:https://www.cnblogs.com/1832921tongjieducn/p/10068397.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!