l= {1,2,3,1} #此处应说明集合“去重”的效果
#定义可变集合
set_test=set(‘hello’) #此处应说明集合的“无序性”
set_test
{‘l’, ‘o’, ‘e’, ‘h’}
#改为不可变集合frozenset
f_set_test=frozenset(set_test)
f_set_test
frozenset({‘l’, ‘e’, ‘h’, ‘o’})
除了刚刚我们学过的交集之外,集合还可以做其他的关系运算。
继续以引子为例,现在已知两个集合分别是学习linux班的同学和学习python班的同学
&.&=:交集——既学习linux课程也学习python课程的同学
l= {‘张三’,‘李四’,‘老男孩’}
p = {‘张三’,‘李四’,‘alex’}
print(l.intersection§)
print(l&p)
|,|=:合集,也叫并集——linux班和python班的所有同学
这里同学们不可以单纯的认为python班的人数+linux班的人数就是结果,如果两班人数相加应该是6人。但学习Linux班的张三和李四还同时在python班学习,因此我们实际上总共只有四个学员。求并集除了合并效果之外还有去重功能
l= {‘张三’,‘李四’,‘老男孩’}
p = {‘张三’,‘李四’,‘alex’}
print(l.union§)
print(l|p)
-,-=:差集——只在linux而不python班的同学
l= {‘张三’,‘李四’,‘老男孩’}
p = {‘张三’,‘李四’,‘alex’}
print(l.difference§)
print(l-p)
,=:对称差集——只在linux班或只在python班的同学
a = {1,2,3}
b = {2,3,4,5}
print(a.symmetric_difference(b))
print(a^b)
包含关系
in,not in:判断某元素是否在集合内
==,!=:判断两个集合是否相等
两个集合之间一般有三种关系,相交、包含、不相交。在Python中分别用下面的方法判断:
-
set.isdisjoint(s):判断两个集合是不是不相交
-
set.issuperset(s):判断集合是不是包含其他集合,等同于a>=b
-
set.issubset(s):判断集合是不是被其他集合包含,等同于a<=b
元素的增加
单个元素的增加 : add(),add的作用类似列表中的append
对序列的增加 : update(),而update类似extend方法,update方法可以支持同时传入多个参数:
a={1,2}
a.update([3,4],[1,2,7])
a
{1, 2, 3, 4, 7}
a.update(“hello”)
a
{1, 2, 3, 4, 7, ‘h’, ‘e’, ‘l’, ‘o’}
a.add(“hello”)
a
{1, 2, 3, 4, ‘hello’, 7, ‘h’, ‘e’, ‘l’, ‘o’}
元素的删除
集合删除单个元素有两种方法:
元素不在原集合中时:
set.discard(x)不会抛出异常
set.remove(x)会抛出KeyError错误
a={1,2,3,4}
a.discard(1)
a
{2, 3, 4}
a.discard(1)
a
{2, 3, 4}
a.remove(1)
Traceback (most recent call last):
File “”, line 1, in
KeyError: 1
pop():由于集合是无序的,pop返回的结果不能确定,且当集合为空时调用pop会抛出KeyError错误,
clear():清空集合
a={3,“a”,2.1,1}
a.pop()
a.pop()
a.clear()
a
set()
a.pop()
Traceback (most recent call last):
File “”, line 1, in
KeyError: ‘pop from an empty set’
class set(object):
“”"
set() -> new empty set object
set(iterable) -> new set object
Build an unordered collection of unique elements.
“”"
def add(self, *args, **kwargs): # real signature unknown
“”"
Add an element to a set.
This has no effect if the element is already present.
“”"
pass
def clear(self, *args, **kwargs): # real signature unknown
“”" Remove all elements from this set. “”"
pass
def copy(self, *args, **kwargs): # real signature unknown
“”" Return a shallow copy of a set. “”"
pass
def difference(self, *args, **kwargs): # real signature unknown
“”"
相当于s1-s2
Return the difference of two or more sets as a new set.
(i.e. all elements that are in this set but not the others.)
“”"
pass
def difference_update(self, *args, **kwargs): # real signature unknown
“”" Remove all elements of another set from this set. “”"
pass
def discard(self, *args, **kwargs): # real signature unknown
“”"
与remove功能相同,删除元素不存在时不会抛出异常
Remove an element from a set if it is a member.
If the element is not a member, do nothing.
“”"
pass
def intersection(self, *args, **kwargs): # real signature unknown
“”"
相当于s1&s2
Return the intersection of two sets as a new set.
(i.e. all elements that are in both sets.)
“”"
pass
def intersection_update(self, *args, **kwargs): # real signature unknown
“”" Update a set with the intersection of itself and another. “”"
pass
def isdisjoint(self, *args, **kwargs): # real signature unknown
“”" Return True if two sets have a null intersection. “”"
pass
def issubset(self, *args, **kwargs): # real signature unknown
“”"
相当于s1<=s2
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注:Python)
LFr-1713633538622)]
[外链图片转存中…(img-CYpTiysq-1713633538623)]
[外链图片转存中…(img-Wp17Jr1W-1713633538623)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注:Python)