python3 集合的基本用法


python3 集合的基本用法

Python3 集合

集合(set)是一个无序的不重复元素序列。

可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。

创建格式:

parame = {value01,value02,...}
或者
set(value)
>>> basket = {'apple', 'orange', 'apple', 'pear', 'orange', 'banana'}
>>> print(basket)                      # 这里演示的是去重功能
{'orange', 'banana', 'pear', 'apple'}
>>> 'orange' in basket                 # 快速判断元素是否在集合内
True
>>> 'crabgrass' in basket
False

>>> # 下面展示两个集合间的运算.
...
>>> a = set('abracadabra')
>>> b = set('alacazam')
>>> a                                  
{'a', 'r', 'b', 'c', 'd'}
>>> a - b                              # 集合a中包含而集合b中不包含的元素
{'r', 'd', 'b'}
>>> a | b                              # 集合a或b中包含的所有元素
{'a', 'c', 'r', 'd', 'b', 'm', 'z', 'l'}
>>> a & b                              # 集合a和b中都包含了的元素
{'a', 'c'}
>>> a ^ b                              # 不同时包含于a和b的元素
{'r', 'd', 'b', 'm', 'z', 'l'}

类似列表推导式,同样集合支持集合推导式(Set comprehension):

>>> a = {x for x in 'abracadabra' if x not in 'abc'}
>>> a
{'r', 'd'}

集合的基本操作

1、添加元素

语法格式如下:

s.add( x )

将元素 x 添加到集合 s 中,如果元素已存在,则不进行任何操作。

>>> thisset = set(("Google", "Runoob", "Taobao"))
>>> thisset.add("Facebook")
>>> print(thisset)
{'Taobao', 'Facebook', 'Google', 'Runoob'}

还有一个方法,也可以添加元素,且参数可以是列表,元组,字典等,语法格式如下:

s.update( x )

x 可以有多个,用逗号分开。

>>> thisset = set(("Google", "Runoob", "Taobao"))
>>> thisset.update({1,3})
>>> print(thisset)
{1, 3, 'Google', 'Taobao', 'Runoob'}
>>> thisset.update([1,4],[5,6])  
>>> print(thisset)
{1, 3, 4, 5, 6, 'Google', 'Taobao', 'Runoob'}
>>>

2、移除元素

语法格式如下:

s.remove( x )

将元素 x 从集合 s 中移除,如果元素不存在,则会发生错误。

>>> thisset = set(("Google", "Runoob", "Taobao"))
>>> thisset.remove("Taobao")
>>> print(thisset)
{'Google', 'Runoob'}
>>> thisset.remove("Facebook")   # 不存在会发生错误
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
KeyError: 'Facebook'
>>>

此外还有一个方法也是移除集合中的元素,且如果元素不存在,不会发生错误。格式如下所示:

s.discard( x )
>>> thisset = set(("Google", "Runoob", "Taobao"))
>>> thisset.discard("Facebook")  # 不存在不会发生错误
>>> print(thisset)
{'Taobao', 'Google', 'Runoob'}

我们也可以设置随机删除集合中的一个元素,语法格式如下:

s.pop() 
thisset = set(("Google", "Runoob", "Taobao", "Facebook"))
x = thisset.pop()

print(x)

输出结果:

$ python3 test.py 
Runoob

多次执行测试结果都不一样。

set 集合的 pop 方法会对集合进行无序的排列,然后将这个无序排列集合的左面第一个元素进行删除。

3、计算集合元素个数

语法格式如下:

len(s)

计算集合 s 元素个数。

>>> thisset = set(("Google", "Runoob", "Taobao"))
>>> len(thisset)
3

4、清空集合

语法格式如下:

s.clear()

清空集合 s。

>>> thisset = set(("Google", "Runoob", "Taobao"))
>>> thisset.clear()
>>> print(thisset)
set()

5、判断元素是否在集合中存在

语法格式如下:

x in s

判断元素 x 是否在集合 s 中,存在返回 True,不存在返回 False。

>>> thisset = set(("Google", "Runoob", "Taobao"))
>>> "Runoob" in thisset
True
>>> "Facebook" in thisset
False
>>>

集合内置方法完整列表

add()

描述

add() 方法用于给集合添加元素,如果添加的元素在集合中已存在,则不执行任何操作。

语法

add()方法语法:

set.add(elmnt)

参数

  • elmnt – 必需,要添加的元素。

返回值

无。

实例

以下实例展示了 add() 方法的使用:

fruits = {"apple", "banana", "cherry"}
fruits.add("orange") 
print(fruits)

输出结果为:

{'apple', 'banana', 'orange', 'cherry'}

已存在的元素,则不执行添加操作:

fruits = {"apple", "banana", "cherry"}
fruits.add("apple")
print(fruits)

输出结果为:

{'apple', 'banana', 'cherry'}
clear()

描述

clear() 方法用于移除集合中的所有元素。

语法

clear()方法语法:

set.clear()

参数

  • 无。

返回值

无。

实例

移除 fruits 集合中的所有元素:

fruits = {"apple", "banana", "cherry"}
fruits.clear()
print(fruits)

输出结果为:

set()
copy()

描述

copy() 方法用于拷贝一个集合。

语法

copy() 方法语法:

set.copy()

参数

  • 无。

返回值

无。

实例

拷贝 fruits 集合:

fruits = {"apple", "banana", "cherry"}
x = fruits.copy()
print(x)

输出结果为:

{'cherry', 'banana', 'apple'}
difference()

描述

difference() 方法用于返回集合的差集,即返回的集合元素包含在第一个集合中,但不包含在第二个集合(方法的参数)中。

语法

difference() 方法语法:

set.difference(set)

参数

  • set – 必需,用于计算差集的集合

返回值

返回一个新的集合。

实例

返回一个集合,元素包含在集合 x ,但不在集合 y :

x = {"apple", "banana", "cherry"}
y = {"google", "microsoft", "apple"}
 
z = x.difference(y) 
 
print(z)

输出结果为:

{'cherry', 'banana'}
difference_update()

描述

difference_update() 方法用于移除两个集合中都存在的元素。

difference_update() 方法与 difference() 方法的区别在于 difference() 方法返回一个移除相同元素的新集合,而 difference_update() 方法是直接在原来的集合中移除元素,没有返回值。

语法

difference_update() 方法语法:

set.difference_update(set)

参数

  • set – 必需,用于计算差集的集合

返回值

无。

实例

移除两个集合都包含的元素:

x = {"apple", "banana", "cherry"}
y = {"google", "microsoft", "apple"}
 
x.difference_update(y) 
 
print(x)

输出结果为:

{'cherry', 'banana'}
discard()

描述

discard() 方法用于移除指定的集合元素。

该方法不同于 remove() 方法,因为 remove() 方法在移除一个不存在的元素时会发生错误,而 discard() 方法不会。

语法

discard() 方法语法:

set.discard(value)

参数

  • value – 必需,要移除的元素

返回值

无。

实例

移除集合中的元素 banana:

fruits = {"apple", "banana", "cherry"}
 
fruits.discard("banana") 
 
print(fruits)

输出结果为:

{'cherry', 'apple'}
intersection()

描述

intersection() 方法用于返回两个或更多集合中都包含的元素,即交集。

语法

intersection() 方法语法:

set.intersection(set1, set2 ... etc)

参数

  • set1 – 必需,要查找相同元素的集合
  • set2 – 可选,其他要查找相同元素的集合,可以多个,多个使用逗号 , 隔开

返回值

返回一个新的集合。

实例

返回一个新集合,该集合的元素既包含在集合 x 又包含在集合 y 中:

x = {"apple", "banana", "cherry"}
y = {"google", "runoob", "apple"}
 
z = x.intersection(y) 
 
print(z)

输出结果为:

{'apple'}

计算多个集合的交集:

x = {"a", "b", "c"}
y = {"c", "d", "e"}
z = {"f", "g", "c"}
 
result = x.intersection(y, z)
 
print(result)

输出结果为:

{'c'}
intersection_update()

描述

intersection_update() 方法用于获取两个或更多集合中都重叠的元素,即计算交集。

intersection_update() 方法不同于 intersection() 方法,因为 intersection() 方法是返回一个新的集合,而 intersection_update() 方法是在原始的集合上移除不重叠的元素。

语法

intersection_update() 方法语法:

set.intersection_update(set1, set2 ... etc)

参数

  • set1 – 必需,要查找相同元素的集合
  • set2 – 可选,其他要查找相同元素的集合,可以多个,多个使用逗号 , 隔开

返回值

无。

实例

移除 x 集合中不存在于 y 集合中的元素:

x = {"apple", "banana", "cherry"}  # y 集合不包含 banana 和 cherry,被移除 
y = {"google", "runoob", "apple"}
 
x.intersection_update(y) 
 
print(x)

输出结果为:

{'apple'}

计算多个集合的并集:

x = {"a", "b", "c"}
y = {"c", "d", "e"}
z = {"f", "g", "c"}
 
x.intersection_update(y, z)
 
print(x)

输出结果为:

{'c'}
isdisjoint()

描述

isdisjoint() 方法用于判断两个集合是否包含相同的元素,如果没有返回 True,否则返回 False。。

语法

isdisjoint() 方法语法:

set.isdisjoint(set)

参数

  • set – 必需,要比较的集合

返回值

返回布尔值,如果不包含返回 True,否则返回 False。

实例

判断集合 y 中是否有包含 集合 x 的元素:

x = {"apple", "banana", "cherry"}
y = {"google", "runoob", "facebook"}
 
z = x.isdisjoint(y) 
 
print(z)

输出结果为:

True

如果包含返回 False:

x = {"apple", "banana", "cherry"}
y = {"google", "runoob", "apple"}
 
z = x.isdisjoint(y) 
 
print(z)

输出结果为:

False
issubset()

描述

issubset() 方法用于判断集合的所有元素是否都包含在指定集合中,如果是则返回 True,否则返回 False。

语法

issubset() 方法语法:

set.issubset(set)

参数

  • set – 必需,要比查找的集合

返回值

返回布尔值,如果都包含返回 True,否则返回 False。

实例

判断集合 x 的所有元素是否都包含在集合 y 中:

x = {"a", "b", "c"}
y = {"f", "e", "d", "c", "b", "a"}
 
z = x.issubset(y) 
 
print(z)

输出结果为:

True

如果没有全部包含返回 False:

x = {"a", "b", "c"}
y = {"f", "e", "d", "c", "b"}
 
z = x.issubset(y) 
 
print(z)

输出结果为:

False
issuperset()

描述

issuperset() 方法用于判断指定集合的所有元素是否都包含在原始的集合中,如果是则返回 True,否则返回 False。

语法

issuperset() 方法语法:

set.issuperset(set)

参数

  • set – 必需,要比查找的集合

返回值

返回布尔值,如果都包含返回 True,否则返回 False。

实例

判断集合 y 的所有元素是否都包含在集合 x 中:

x = {"f", "e", "d", "c", "b", "a"}
y = {"a", "b", "c"}
 
z = x.issuperset(y) 
 
print(z)

输出结果为:

True

如果没有全部包含返回 False:

x = {"f", "e", "d", "c", "b"}
y = {"a", "b", "c"}
 
z = x.issuperset(y) 
 
print(z)

输出结果为:

False
pop()

描述

pop() 方法用于随机移除一个元素。

语法

pop() 方法语法:

set.pop()

参数

返回值

返回移除的元素。

实例

随机移除一个元素:

fruits = {"apple", "banana", "cherry"}
 
fruits.pop() 
 
print(fruits)

输出结果为:

{'apple', 'banana'}

输出返回值:

fruits = {"apple", "banana", "cherry"}
 
x = fruits.pop() 
 
print(x)

输出结果为:

banana
remove()

描述

remove() 方法用于移除集合中的指定元素。

该方法不同于 discard() 方法,因为 remove() 方法在移除一个不存在的元素时会发生错误,而 discard() 方法不会。

语法

remove() 方法语法:

set.remove(item)

参数

  • item – 要移除的元素

返回值

没有返回值。

实例

移除元素 banana:

fruits = {"apple", "banana", "cherry"}
 
fruits.remove("banana") 
 
print(fruits)

输出结果为:

{'cherry', 'apple'}
symmetric_difference()

描述

symmetric_difference() 方法返回两个集合中不重复的元素集合,即会移除两个集合中都存在的元素。

语法

symmetric_difference() 方法语法:

set.symmetric_difference(set)

参数

  • set – 集合

返回值

返回一个新的集合。

实例

返回两个集合组成的新集合,但会移除两个集合的重复元素:

x = {"apple", "banana", "cherry"}
y = {"google", "runoob", "apple"}
 
z = x.symmetric_difference(y) 
 
print(z)

输出结果为:

{'google', 'cherry', 'banana', 'runoob'}
symmetric_difference_update()

描述

symmetric_difference_update() 方法移除当前集合中在另外一个指定集合相同的元素,并将另外一个指定集合中不同的元素插入到当前集合中。

语法

symmetric_difference_update() 方法语法:

set.symmetric_difference_update(set)

参数

  • set – 要检测的集合

返回值

无。

实例

在原始集合 x 中移除与 y 集合中的重复元素,并将不重复的元素插入到集合 x 中:

x = {"apple", "banana", "cherry"}
y = {"google", "runoob", "apple"}
 
x.symmetric_difference_update(y) 
 
print(x)

输出结果为:

{'google', 'cherry', 'banana', 'runoob'}
union()

描述

union() 方法返回两个集合的并集,即包含了所有集合的元素,重复的元素只会出现一次。

语法

union() 方法语法:

set.union(set1, set2...)

参数

  • set1 – 必需,合并的目标集合
  • set2 – 可选,其他要合并的集合,可以多个,多个使用逗号 , 隔开。

返回值

返回一个新集合。

实例

合并两个集合,重复元素只会出现一次:

x = {"apple", "banana", "cherry"}
y = {"google", "runoob", "apple"}
 
z = x.union(y) 
 
print(z)

输出结果为:

{'cherry', 'runoob', 'google', 'banana', 'apple'}

合并多个集合:

x = {"a", "b", "c"}
y = {"f", "d", "a"}
z = {"c", "d", "e"}
 
result = x.union(y, z) 
 
print(result)

输出结果为:

{'c', 'd', 'f', 'e', 'b', 'a'}
update()

描述

update() 方法用于修改当前集合,可以添加新的元素或集合到当前集合中,如果添加的元素在集合中已存在,则该元素只会出现一次,重复的会忽略。

语法

update() 方法语法:

set.update(set)

参数

  • set – 必需,可以是元素或集合

返回值

  • 无。

  • 实例

  • 合并两个集合,重复元素只会出现一次:

  • x = {"apple", "banana", "cherry"}
    y = {"google", "runoob", "apple"}
     
    x.update(y) 
     
    print(x)
    
  • 输出结果为:

  • {'banana', 'apple', 'google', 'runoob', 'cherry'}
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值