如何将值列表添加到现有集?


当前回答

集合不能有可变的元素/成员。列表是可变的,不能是集合的成员。

因为集合是可变的,所以你不能拥有集合的集合! 不过你可以买一套冷冻套装。

(同样的“可变性要求”也适用于字典的键。)

其他答案已经给出了代码,我希望这能给你一些启发。 我希望亚历克斯·马特利能给出更多细节。

其他回答

列表对象是不可哈希的。你可能想把它们转换成元组。

添加列表的内容

使用set.update()或|=操作符:

>>> a = set('abc')
>>> a
{'a', 'b', 'c'}

>>> xs = ['d', 'e']
>>> a.update(xs)
>>> a
{'e', 'b', 'c', 'd', 'a'}

>>> xs = ['f', 'g']
>>> a |= set(xs)
>>> a
{'e', 'b', 'f', 'c', 'd', 'g', 'a'}

添加列表本身

不可能直接将列表本身添加到set中,因为set元素必须是可哈希的。

相反,可以先将列表转换为元组:

>>> a = {('a', 'b', 'c')}

>>> xs = ['d', 'e']
>>> a.add(tuple(xs))
>>> a
{('a', 'b', 'c'), ('d', 'e')}

您不能将列表添加到集合中,因为列表是可变的,这意味着您可以在将列表添加到集合后更改列表的内容。

然而,你可以向集合中添加元组,因为你不能改变元组的内容:

>>> a.add(('f', 'g'))
>>> print a
set(['a', 'c', 'b', 'e', 'd', ('f', 'g')])

编辑:一些解释:文档将集合定义为不同哈希对象的无序集合。对象必须是可哈希的,这样查找、添加和删除元素可以比每次执行这些操作时查看每个单独的元素更快。维基百科的文章中解释了使用的具体算法。python的哈希算法在effbot.org上有解释,python参考中有Pythons __hash__函数。

一些事实:

集合元素和字典键都必须是可哈希的 一些不可哈希的数据类型: List:使用tuple代替 Set:使用frozenset代替 词典:没有官方对应的词典,但有一些 食谱 默认情况下,对象实例是可哈希的,每个实例都有唯一的哈希。如python参考中所述,您可以覆盖此行为。

尝试使用* unpack,如下所示:

>>> a=set('abcde')
>>> a
{'a', 'd', 'e', 'b', 'c'}
>>> l=['f','g']
>>> l
['f', 'g']
>>> {*l, *a}
{'a', 'd', 'e', 'f', 'b', 'g', 'c'}
>>> 

非编辑器版本:

a=set('abcde')
l=['f', 'g']
print({*l, *a})

输出:

{'a', 'd', 'e', 'f', 'b', 'g', 'c'}

希望这能有所帮助:

>>> seta = set('1234')
>>> listb = ['a','b','c']
>>> seta.union(listb)
set(['a', 'c', 'b', '1', '3', '2', '4'])
>>> seta
set(['1', '3', '2', '4'])
>>> seta = seta.union(listb)
>>> seta
set(['a', 'c', 'b', '1', '3', '2', '4'])