标签:and intersect 比较 union 集合 不能 res bsp 汉字
集合的定义:
集合和列表([ ]) 与 字典 ( { }) 不同,没有特别的特别的语法格式。可以使用set () 创建。
集合同字典一样是无序的。也是不具有重复性的。因此可以把列表变成集合进行去重。
集合具有特别的关系性能,交集,并集,差集等。
# hanbb come on! list1 = [1,4,5,7,3,6,7,9] # 列表 s1 = set(list1) # remove repeat,such as 7 ; 自动去重 (列表转化为集合) s2 = set([1,6,0,66,22,8,4]) # another way express set s3 = set("hello") # 这是字符变成集合吗? print(s3) # {‘h‘, ‘o‘, ‘l‘, ‘e‘} print(s2) # {0, 2, 66, 4, 6, 8, 22} print(s1) # {1, 3, 4, 5, 6, 7, 9}
集合的基本操作:新增;移除;复制;求长度(没有修改?)
# basic operation # Add one s1.add(‘BB8‘) print(s1) # {1, 3, 4, 5, 6, 7, ‘BB8‘, 9} # add more s1.update( ["猪八戒","孙悟空"] ) # 注意[] # {1, ‘孙悟空‘, 3, 4, 5, 6, 7, ‘BB8‘, 9, ‘猪八戒‘} print(s1) # s1.update(2,4,6) s1.update([2,4,6]) # {1, 2, 3, 4, 5, 6, 7, 9, ‘猪八戒‘, ‘BB8‘, ‘孙悟空‘} print(s1) s1.update("BB7") # update"BB7" and add "BB8" 区别明显 # {1, 2, 3, 4, 5, 6, 7, 9, ‘7‘, ‘BB8‘, ‘孙悟空‘, ‘猪八戒‘, ‘B‘} print(s1) # Remove # s1.remove("1","2","3") # 不能移除多个 # remove() takes exactly one argument (3 given) # s1.remove(‘1‘) # 数据会出错,为啥呀 # s1.remove(‘1‘) s1.remove(‘B‘) # 字母不会,汉字也不会 # {1, 2, 3, 4, 5, 6, 7, 9, ‘猪八戒‘, ‘孙悟空‘, ‘BB8‘, ‘7‘} print(s1) # copy s4 = s2.copy() print(s2) # length print(len(s1)) # 12
集合的关系运算:交集,并集,差集(两个集合位置有影响),对称差集。
# relationship print(s1.intersection(s2)) # {1, 4, 6} print(s1.union(s2)) # {0, 1, 2, 3, 4, 5, 6, 7, 66, 9, 8, ‘7‘, ‘BB8‘, 22, ‘猪八戒‘, ‘孙悟空‘} print(s1.difference(s2)) # 在1中,不在2中 # {‘BB8‘, 2, 3, ‘7‘, 5, 7, 9, ‘孙悟空‘, ‘猪八戒‘} print(s2.difference(s1)) # 在2中,不在1中 # {0, 8, 66, 22} print(s1.symmetric_difference(s2)) # 对称差集(项在t或s中,但不会同时出现在二者中) # {0, 66, 2, ‘7‘, 3, 5, 8, 7, 9, ‘孙悟空‘, 22, ‘猪八戒‘, ‘BB8‘}
集合值的访问:
# 访问集合值 print("1" in s1) # False print("BB8" in s1) # True
print("1" not in s1) # True for i in s1: print(i) ‘‘‘1 2 3 4 5 6 7 孙悟空 9 BB8 7 猪八戒‘‘‘
集合还是比较容易理解和掌握的,还有操作符号的运算。
标签:and intersect 比较 union 集合 不能 res bsp 汉字
原文地址:http://www.cnblogs.com/hanbb/p/7208600.html