python - Python中有 'multimap'实现吗?

标签 python dictionary

我是 Python 新手,熟悉 Multimaps 的实现在 other languages . Python 是否内置了这样的数据结构,或者在常用库中可用?

为了说明我所说的“多图”是什么意思:

a = multidict()
a[1] = 'a'
a[1] = 'b'
a[2] = 'c'

print(a[1])  # prints: ['a', 'b']
print(a[2])  # prints: ['c']

最佳答案

标准库中不存在这样的东西。您可以使用 defaultdict不过:

>>> from collections import defaultdict
>>> md = defaultdict(list)
>>> md[1].append('a')
>>> md[1].append('b')
>>> md[2].append('c')
>>> md[1]
['a', 'b']
>>> md[2]
['c']

(你可能想要使用 set 而不是 list,在这种情况下你会调用 .add 而不是 。追加。)


顺便说一句:看看你写的这两行:

a[1] = 'a'
a[1] = 'b'

这似乎表明您希望表达式 a[1] 等于两个不同的值。这对于字典是不可能的,因为它们的键是唯一的,并且它们中的每一个都与单个值相关联。但是,您可以 做的是一一提取与给定键关联的列表中的所有值。您可以使用iter随后连续调用next为了那个原因。或者你可以只使用两个循环:

>>> for k, v in md.items():
...     for w in v:
...         print("md[%d] = '%s'" % (k, w))
... 
md[1] = 'a'
md[1] = 'b'
md[2] = 'c'

关于python - Python中有 'multimap'实现吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1731971/

相关文章:

安卓蓝牙设备定位器

database - 在数据库列中存储键值对

python - 为什么这两种在Python中创建新字典的方法不是同义词

Python:如何忽略异常并继续?

python - python 中的自定义类 : does a method HAVE to be called with an instance?

python - 使用python将特殊格式的文件解析为字典列表

python - Python 中 set() 中的 "add"操作或 dict() 中的 "insert"实际上是 O(n),其中 n 是 key 字符串的长度?

Raspberry Pi 上的 Python/MySQLdb 问题

Python导入结构

python - 为什么 SymPy 不直接求解该波函数的标准化?