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


当前回答

尝试使用* 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'}

其他回答

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

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

>>> 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参考中所述,您可以覆盖此行为。

您将希望使用可哈希的元组(不能像列表那样对可变对象进行哈希)。

>>> a = set("abcde")
>>> a
set(['a', 'c', 'b', 'e', 'd'])
>>> t = ('f', 'g')
>>> a.add(t)
>>> a
set(['a', 'c', 'b', 'e', 'd', ('f', 'g')])

我发现我今天也需要做一些类似的事情。该算法知道何时创建一个需要添加到集合中的新列表,但不知道何时完成对列表的操作。

总之,我想让set使用id而不是hash。因此,我发现mydict[id(mylist)] = mylist而不是myset.add(mylist)提供我想要的行为。

联合是最简单的方法:

list0 = ['a', 'b', 'c']

set0 = set()
set0.add('d')
set0.add('e')
set0.add('f')

set0 = set0.union(list0)

print(set0)

输出:

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

尝试使用* 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'}