python - 创建具有两个值的字典时遗漏的值

标签 python dictionary python-itertools

我有如下两个列表。

count = (1, 0, 0, 2, 0, 0, 1, 1, 1, 2)
bins = [[2.0, 3.0], [3.0, 4.0], [4.0, 5.0], [5.0, 6.0], [6.0, 7.0], [7.0, 8.0], [8.0, 9.0], [9.0, 10.0], [10.0, 11.0], [11.0, 12.0], [12.0]]

我尝试使用以下方法创建字典;

dictionary = dict(itertools.izip(count, bins))

它给了我 {"0": [7.0, 8.0], "1": [10.0, 11.0], "2": [11.0, 12.0]}

它只给出了唯一的键值,但我需要得到所有的键值对,如下所示。

{"0": [3.0, 4.0],"0": [4.0, 5.0],"0": [6.0, 7.0],"0": [7.0, 8.0], "1": [2.0, 3.0],"1": [8.0, 9.0], "1": [9.0, 10.0], "1": [10.0, 11.0], "2": [6.0, 7.0] ,"2": [11.0, 12.0]}

或者上面字典中的键和值的交换是可以接受的。(因为键应该是唯一的) 我该怎么做?

最佳答案

您不能将 list 用作字典的键,因为它是可变的。

您可以将 list 转换为 tuple:

>>> count = (1, 0, 0, 2, 0)
>>> bins = [[2.0, 3.0], [3.0, 4.0], [4.0, 5.0], [5.0, 6.0], [6.0, 7.0], [7.0, 8.0]]

>>> {tuple(key): value for (key, value) in zip(bins, count)}
{(4.0, 5.0): 0,
 (3.0, 4.0): 0,
 (5.0, 6.0): 2,
 (2.0, 3.0): 1,
 (6.0, 7.0): 0}

如果要序列化为json,键需要是字符串。您可以将 bins 转换为字符串:

>>> {str(key): value for (key, value) in zip(bins, count)}
{'[2.0, 3.0]': 1, '[4.0, 5.0]': 0, '[6.0, 7.0]': 0, '[5.0, 6.0]': 2, '[3.0, 4.0]': 0}

>>> import json
>>> json.dumps(_)
'{"[2.0, 3.0]": 1, "[4.0, 5.0]": 0, "[6.0, 7.0]": 0, "[5.0, 6.0]": 2, "[3.0, 4.0]": 0}'

或者,只需序列化对,并在接收端制作字典:

>>> zip(bins, count)
[([2.0, 3.0], 1), ([3.0, 4.0], 0), ([4.0, 5.0], 0), ([5.0, 6.0], 2), ([6.0, 7.0], 0)]

>>> import json
>>> json.dumps(_)
'[[[2.0, 3.0], 1], [[3.0, 4.0], 0], [[4.0, 5.0], 0], [[5.0, 6.0], 2], [[6.0, 7.0], 0]]'

关于python - 创建具有两个值的字典时遗漏的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33773586/

相关文章:

json - 如何将 map 嵌入到结构中,使其具有平面 json 表示

python - Django - 以一种形式保存多个选择框

python - 如何创建一个新字典,其键是来自另一个字典的键?不可散列类型错误

python - 在 Python 中删除旧目录

Python 字典排序列表,部分标签可能缺失

Python itertools : Cartesian product with filtering of empty strings

Python 用字典格式填充字符串

python - 如何从具有不同长度列表的字典创建字典列表

python - 如何使用 beautifulsoup 将网站中的文本保存为 .txt 文件?

python - 评估每个单元格并返回列头,如果不是 null pandas df