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

python 数据类型 之 集合

时间:2018-07-08 13:54:51      阅读:162      评论:0      收藏:0      [点我收藏+]

标签:多个   disjoint   函数   pre   集合推导式   remove   ash   数学   bsp   

集合是一个数学概念:由一个或多个确定的元素所构成的整体叫做集合

 

集合的三个特性:

  1.确定性 (element必须可hash,不可变类型是可hash的)

  2.互异性(集合中element 不能重复)

  3.无序性(集合中没有先后之分,例如集合:{3,4,6}  等于{6,4,3})

 

  #集合的存在意义在于去重和关系运算

集合的定义:

st = set(‘hello‘)
lis = list(‘hello‘)
print(st)
# {‘h‘, ‘o‘, ‘l‘, ‘e‘}
print(lis)
# [‘h‘, ‘e‘, ‘l‘, ‘l‘, ‘o‘]
# 【注意】
dic={}#空花括号{},代表定义字典
print(‘dic type:%s‘%type(dic))
>>:dic type:<class ‘dict‘>
st = {‘h‘, ‘e‘, ‘l‘, ‘l‘, ‘o‘}#定义的时候集合内出现了重复的项,但是并没有报错,只是剔除了重复element
print(st)
# {‘h‘, ‘o‘, ‘l‘, ‘e‘}

1)集合是无序的, 不重复的数据类型; 
2)因此不支持索引,也不支持切片;也不支持重复;也不支持连接; 
3)支持成员操作符; 
4)支持for循环;



# print(type(set([i for i in range(0, 9)])))
lis = [i for i in range(0, 9)]
d = {}.fromkeys(lis)
# print(type(d))
# print(d)
# print(d.keys())
# for key in d.keys():
# print(key)

st = set([i for i in range(0, 3)])
# print(‘st type:%s st:%s‘ % (type(st), st))
# st type:<class ‘set‘> st:{0, 1, 2}

# 增加 element

st.add(‘new element‘)
st2 = {9, 8, 7, }

#更新
st.update(st2) # 可以看成集合的凭接吗
st.update(‘t‘) # 单个元素,或者是集合本身也可以进行拼接
# st.add({‘b‘, ‘y‘}) # 报错 TypeError: unhashable type: ‘set‘
# print(st)

# 查找 element
s1 = set({i for i in range(1, 8)})
s2 = set({i for i in range(6, 10)})

# 交集
# print(s1 & s2) # {6, 7}
# print(s1.intersection(s2)) # {6, 7}
# s1.intersection_update(s2)
# print(s1) # {6, 7}

# 并集
# print(s1 | s2)# {1, 2, 3, 4, 5, 6, 7, 8, 9}
# print(s1.union(s2)) # {1, 2, 3, 4, 5, 6, 7, 8, 9}

# 差集
# print(s1 - s2)# {1, 2, 3, 4, 5}
# print(s2 - s1)# {8, 9}
#st.difference(s2)
#
# #对等差分 [取反 交集]
# print(s1 ^ s2) #{1, 2, 3, 4, 5, 8, 9}


#超集和子集
boys = {‘zzy‘,‘yqw‘,‘dw‘,‘wzc‘,‘lyb‘,‘wym‘,‘chy‘}
zoudu = {‘wzc‘,‘lyb‘,‘wym‘}
girls = {‘lsy‘,‘mmf‘,‘syj‘}

#issuperset()  检测当前集合是否是另一个集合的超集
result = boys.issuperset(zoudu)
print(result)

#issubset()  检测当前集合是否是另一个集合的子集
result = zoudu.issubset(boys)
print(result)

#isdisjoint()  检测2个集合是否不存在交集  存在交集 False
result = boys.isdisjoint(girls)
print(result)



# 删除
# print(st)
# print(len(st))
st.remove(‘new element‘)#删除指定的元素,不存在报错
st.remove(2)
# print(st.pop())#随机删除并且返回集合中某个值
# print(st.pop())
# print(st.pop())
# print(st.pop())
# print(st.pop())
# print(st.pop())
# print(st.pop())#假如集合没有元素了,会报错 KeyError: ‘pop from an empty set‘
st.discard(3)
st.discard(3)#删除指定元素 假如元素不存在 不会报错

#清空集合
st.clear()
#赋值集合
new_st =st.copy()

print(st)

dic = {k: v for k, v in enumerate(range(2, 6))}
# {0, 1, ‘t‘, 7, 8, 9}

print("dic type:%s dic value:%s" % (type(dic), dic))
# dic type:<class ‘dict‘> dic value:{0: 2, 1: 3, 2: 4, 3: 5}

print(‘dic.pop:%s‘ % dic.pop(2)) # dic.pop:4

成员检测:
result_in = 2 in st
result_not = 2 not in st
print(result_in)
print(result_not)

集合推导式:
st_1 = { key_value for key_value in range(2,8) }

带有判断的集合推导式
st_2 = { key_value for key_value in range(2,17) if (key_value%2)==1 }


#冰冻集合
#冰冻集合是一种特殊的集合类型,也是集合(集合是列表的话,冰冻集合就是元组)
#创建冰冻集合
#一般不会创建空的冰冻集合
var = frozenset()
print(var,type(var))

#带有数据的冰冻集合
var = frozenset((‘qs‘,‘szx‘,‘bjh‘,‘acs‘))# 不可变集合
print(var,type(var))

#成员检测
result = ‘szx‘ in var
print(result)

#遍历冰冻集合
for i in var:
    print(i)

#集合推导式(无法得到冰冻集合,可以得到集合,列表,元组,字典类型)
result = {i for i in var}
print(result,type(result))

#函数
#冰冻集合可以使用集合的函数(不修改集合本身的函数都可以使用)
var = frozenset((‘qs‘,‘szx‘,‘bjh‘,‘acs‘))

#copy()
result = var.copy()
print(result)

#集合操作  交集,并集,差集,对称差集等  不修改冰冻集合本身就能使用:冰冻集合的操作结果都是冰冻集合
var1 = frozenset((‘qs‘,‘szx‘,‘bjh‘,‘acs‘))
var2 = {‘szx‘,‘bjh‘,‘lc‘,‘wb‘}

#冰冻集合操作
result = var1.union(var2)
print(result)

#普通集合操作(冰冻集合是参考集合)
result = var2.union(var1)
print(result)

















python 数据类型 之 集合

标签:多个   disjoint   函数   pre   集合推导式   remove   ash   数学   bsp   

原文地址:https://www.cnblogs.com/yanxiatingyu/p/9279836.html

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