设为首页 收藏本站
查看: 898|回复: 0

[经验分享] 菜鸟学python之dict-11818322

[复制链接]

尚未签到

发表于 2018-8-13 11:29:32 | 显示全部楼层 |阅读模式
  存储位置=hash(键)
  在搜索时,首先对键进行hash运算,把求得的值当做“键-值对”的存储位置,在结构中按照此位置取“键-值对”进行比较,若键相等,则表示搜索成功。在存储“键-值对”的时候,依照相同的hash函数计算存储位置,并按此位置存放,这种方法就叫做哈希方法,也叫做散列方法。在哈希方法中使用的转换函数hash被称作哈希函数(或者散列函数)。按照此中算法构造出来的表叫做哈希表(或者散列表)。
  哈希函数建立了从“键-值对”到哈希表地址集合的一个映射,有了哈希函数,我们就可以根据键来确定“键-值对”在哈希表中的位置的地址。使用这种方法由于不必进行多次键的比较,所以其搜索速度非常快,很多系统都使用这种方法进行数据的组织和检索。
  举一个例子,有一组“键值对”:<5,”tom”>、<8,”Jane”>、<12,”Bit”>、<17,”Lily”>、<20,”sunny”>,我们按照如下哈希函数对键进行计算:hash(x)=x%17+3;hash(5)=8、hash(8)=11、hash(12)=15、hash(17)=3、hash(20)=6。我们把<5,”tom”>、<8,”Jane”>、<12,”Bit”>、<17,”Lily”>、<20,”sunny”>分别放到地址为8、11、15、3、6的位置上。当要检索17对应的值的时候,只要首先计算17的哈希值为3,然后到地址为3的地方去取数据就可以找到17对应的数据是“Lily”了,可见检索速度是非常快的。
  1.1 字典创建
>>> dict={'name':'python','age':7,'class':'second'}  
>>> dict{'name': 'python', 'age': 7, 'class': 'second'}
  tips:1使用{}; 2key-values之间使用:分割 3,不同项之间采用,分割
  1.2 字典元素访问
  1)通过key做下标访问
>>> dict['age']7  2)通过方法get
>>> dict.get('sex')'male'dict.get()  
>>> dict.get('name')         不存在时默认反悔none
  
>>> dict.get('name','muyou')  指定不存在时返回的内容'muyou'
  2.1 增加字典元素
  不同于list的增加,list如果内部不存在变量则不能直接赋值,必须通过,insert,append等方法;而字典可以直接赋值;存在则改变,不存在则创建新对象并赋值
>>> dict['sex']='fale'  
>>> dict{'name': 'python', 'age': 7, 'class': 'second', 'sex': 'fale'}
  2.2 删除字典元素
  2.2.1 pop弹出
Traceback (most recent call last):   #不同于list,由于无序,所以必须制定索引  
File "<pyshell#179>", line 1, in <module>
  
dict.pop()TypeError: pop expected at least 1 arguments, got 0
  
>>> dict.pop('age')7
  
>>> dict{'name': 'python', 'class': 'second', 'sex': 'fale'}
  2.2.2 popitem弹出项
>>> dict.popitem()   #如果弹出整个item,则可以从后往前弹出('sex', 'fale')  2.2.3 del语句删除
{'name': 'python'}>>> del dict['name']  
>>> dict{}>>> del dict>>> dict<class 'dict'>
  2.2.4 修改元素
  1)直接赋值法  同2.1所示
>>> dict['sex']='make'  
>>> dict['sex']='female'
  
>>> dict{'sex': 'female'}
  2)update修改
>>> dict.update(sex='male')  
>>> dict{'sex': 'male'}
  小结

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-551130-1-1.html 上篇帖子: python3 if __name__ == "__main__" 下篇帖子: python常用模块详解
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表