首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Python 哈希(hash) 散列

标准库里的所有映射类型都是利用 dict 来实现的,因此它们有个共同的限制,即只有可散列的数据类型才能用作这些映射里的键,本文记录Python 中 hash 相关内容。...Python 中可散列的数据类型 官方定义 翻译过来就是: 如果一个对象的哈希值在其生命周期中从不变化(它需要一个 __hash__()方法) ,并且可以与其他对象进行比较(它需要一个 _ eq _ (...如果要把一个对象放入散列表,那么首先要计算这个元素键的散列值。 Python 中可以用 hash() 方法来做这件事情: 内置的 hash() 方法可以用于所有的内置类型对象。...为了获取 my_dict[search_key] 背后的值,Python 首先会调用 hash(search_key) 来计算 search_key 的散列值,把这个值最低 的几位数字当作偏移量,在散列表里查找表元...参考资料 流畅的Python(2017年人民邮电出版社出版) https://docs.python.org/3/glossary.html#term-hashable https://baike.baidu.com

2.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Python的可散列对象

    这里先介绍Python语言中的可散列对象。 散列函数 在介绍散列表以及它在Python中的实现之前,先简要说明散列函数及其工作原理。...不可逆性:散列函数是一个“单向函数”,将字符串输入到散列函数,得到了散列值,但是不能反过来,不能从散列值得到原来的字符串。由于这个特性,它可以用于加密。...Python的内置散列函数 Python的内置函数hash()是一个散列函数,它能够返回输入对象的十进制整数形式的散列值。...显然,10和10.0是两个不同的对象(一个是整数,另外一个是浮点数),而它们的散列值相同。反过来,根据相同的散列值,无法唯一判定输入对象是哪一个。这就是可以用散列加密的原因。...可散列类型 在Python内置的对象类型中,并非都是可散列的,只有那些不可变对象,比如整数、浮点数、字符串、元组等,才是可散列的。

    5K20

    手撕Python之散列类型

    序列类型是有顺序的,散列类型是没有顺序的 字典也是没有顺序的,如果想访问值的话,我们是需要通过键进行获取的 在字典之内不管顺序怎么变我们都能通过键进行访问 字典注意事项 键必须是唯一的 #键必须是唯一的...这个函数会将我们输入的要添加的序列或者是散列给拆分了 #添加序列的话 #update(序列/散列) j.update("你好") print(j) #{1, 2, 3, 5, 6, 'hu', '你'..., '好', '你好啊'} #可以发现我们后面输入的被拆开了 #将我们输入的序列或者是散列类型的数据拆开放到集合中 括号内是不能够写数字的,会报错,因为括号内只能写序列和散列 4.删除 #### 4.1remove...主要是判断某个内容在这一堆是否存在 使用格式:数据 in 序列/散列 判断数据是不是序列/散列的成员 成员运算符的使用 #判断字符p是不是python的成员 print('p'in'pyhton')...'李四''张三''王二'] if "小明" in li:#判断小明在不在名字列表里面 print(True) else: print(False) #False #判断字符q是否不是python

    8310
    领券