True and 1 and 1.0 evaluated to be same in python dictionaries(True 和 1 和 1.0 在 python 字典中被评估为相同)
问题描述
谁能解释一下python字典的这种行为?
Can anyone explain this behaviour of python dictionaries?
d = {}
d[True] = 'Magic'
d[1] = 'Cool'
d[1.0] = 'Hello'
print(d)
# {True: 'Hello'}
为什么它不打印所有其他(键、值)对?
Why does it not print all the other (key, value) pairs?
为什么 True、1 和 1.0 被评估为相同?
Why does True, 1 and 1.0 is evaluated to be the same?
推荐答案
hash
3 项 1, 1.0, True
相同(等于 1
).如果没有冲突,这就是 python 用作字典键的内容.并且由于 1 == 1.0 == True
也是 True
没有冲突.
the hash
of the 3 items 1, 1.0, True
is the same (it equals 1
). that's what python uses as the key for dictionaries if there are no collisions. and as 1 == 1.0 == True
is also True
there are no collisions.
这里有更多关于python 旧实现的详细信息字典.新的实现按照这些思路做事(但保留了顺序).
here are more details about the old implementation of python dictionaries. the new implementation does things along those lines (but preserves the order).
这篇关于True 和 1 和 1.0 在 python 字典中被评估为相同的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:True 和 1 和 1.0 在 python 字典中被评估为相同
基础教程推荐
- 在 Python 中,如果我在一个“with"中返回.块,文件还会关闭吗? 2022-01-01
- 如何让 python 脚本监听来自另一个脚本的输入 2022-01-01
- 线程时出现 msgbox 错误,GUI 块 2022-01-01
- Python kivy 入口点 inflateRest2 无法定位 libpng16-16.dll 2022-01-01
- Dask.array.套用_沿_轴:由于额外的元素([1]),使用dask.array的每一行作为另一个函数的输入失败 2022-01-01
- 用于分类数据的跳跃记号标签 2022-01-01
- 如何在海运重新绘制中自定义标题和y标签 2022-01-01
- 何时使用 os.name、sys.platform 或 platform.system? 2022-01-01
- 使用PyInstaller后在Windows中打开可执行文件时出错 2022-01-01
- 筛选NumPy数组 2022-01-01