Python版本:3.6.2  操作系统:Windows  作者:SmallWZQ

  知识源于生活。Python也是如此。

  提到字典,我首先想到的是数学大师——高斯。

  为何想起他呢?这主要是因为高斯算法嘛。计算1+2+3+...+100,一般人都会从1一直加到100,而高斯却另辟蹊径,找到规律,从而发现“高斯算法”。高斯算法极大地提高运算效率。对于Python中的字典,它与高斯算法异曲同工,同样能提高键值对的查找效率。

  映射(mapping):通过名字来引用值的数据结构。

  字典是Python中唯一内建的映射类型。字典的键值对(Key-Values),键是不可变的,可以为字符串、数字(int、float......)、元组等等。

  字典中的键是唯一的,而值却可以相同。

  Python格式如下:

 phone = {'Jack':'','James':'','Paul':''} #大括号,且键值对之间用冒号(:)隔开

  注:对于上面的代码,可能有读者会疑问:为什么用字符串表示电话号码呢?

  主要是考虑以“0”开头的电话号码。定义电话号码时,以“0”开头会显示错误(Error)。因此,为了考虑周全,字典中电话号码应表示为数字字符串,而不是整数。

  

图1 电话号码错误示例

  1.创建字典和访问元素

  创建方式如下:

d = {'a':'','b':'','c':'99','c':''}
print(d)
d['a']
'97'

  注:字典中即使键相同,也只会输出其中一个(若Key相同,后面的值(Value)会把前面的覆盖掉)。

  2.添加元素

  字典没有insert()方法,但依然能够添加元素。

d = {'a':'','b':'','c':''}
d['d'] = ''
print(d)

  3.删除元素

  字典中删除元素,使用pop()方法。pop()方法用于获得对应于给定键的值,并将该键值对从字典中移除。

d ={‘a':'97','b':'98','c':'99'}
d.pop('b')
''
print(d)
{‘a':'97','c':'99'}

  注:除了pop()方法,还可以使用del方法

  4.修改元素

  字典中的元素如何修改呢?很简单,直接通过Key修改Value。

d ={‘a':'97','b':'98','c':'99'}
d['b'] = ''
print(d['b'])
''
print(d)
d ={‘a':'97','b':'200','c':'99'}

  5.查找元素

  字典中查找元素与修改元素类似,也是通过Key来查找字典中的Value。

d ={‘a':'97','b':'98','c':'99'}
d['b']
''
d['c']
''

  如果字典中没有该Key时,dict会报错。

  

图2 错误提示(KeyError)

  如何避免Key不存在的错误呢?

  1.通过k in d,判断Key是否在dict中: 

‘a’ in d
True
'f' in d
False

  2.get()方法用于更宽松的访问字典项的方法。如果Key不存在,使用get()没有任何异常,仅仅返回None值:

  

                    图3 get()方法示例

  注:通过d.get('f','120')并不能往字典d ={}中添加键-值对。

  6.字典基本操作总结

   ♦len(d):返回d中键-值对的数量;

   ♦d[k]:返回关联到键K上的值(Value);

   ♦d[k] = V:将值V关联到将K上;

   ♦del d[k]:删除键为K的项;

   ♦K in d:检查d中是否含有键K的元素;

   ♦键K类型:字符串、数字或元组,符合条件的不可变类型均可;

   ♦字典格式化字符串:%(Jack)s %(phone)。【其中Jack为键,而phone为dict{}】

  其实,元组不一定可以用于dict的键(Key)

d ={‘a':'97','b':'98','c':'99'}
d[(1,2,3,4,5,6)] = ''
print(d)
d ={‘a':'97','b':'98','c':'99',(1,2,3,4,5,6):'121'}
d[(1,2,[1,2,3])] = ''
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: unhashable type: 'list'

  注:如果元组用于键,元组中不能含有可变内容list,否则编译错误。

  字典总结

  1.字典中元素必须以键值对的形式出现;

  2.字典中的键必须是不可变的,可以是字符串、数字以及元组,并且无法修改;

  3.Key是唯一的,不可重复,而Value可以重复;

  4.字典查找和插入元素极快,并不会随着Key增加而减慢;

  5.字典占用内存大,以空间换取时间;

  6.特别地,当tuple作为字典中的键(Key)时,tuple中不能包含list,否则编译错误。

Python数据结构之三——dict(字典)的更多相关文章

  1. Python - 基础数据类型 dict 字典

    字典简介 字典在 Python 里面是非常重要的数据类型,而且很常用 字典是以关键字(键)为索引,关键字(键)可以是任意不可变类型 字典由键和对应值成对组成,字典中所有的键值对放在 { } 中间,每一 ...

  2. python数据类型之dict(字典)

    dict字典 关注公众号"轻松学编程"了解更多. 1.概述 dict也是一种存储方式,类似于list和tuple,但是,字典采用键-值(key-value)的形式存储. 优点:具有 ...

  3. python基础(六)dict字典和文件操作open

    字典dict 使用key来标注value的数据类型,key和value是一一对应的.在字典中key是唯一的,所以字典也是无序的. #定义一个字典 dict = { 'name' : 'sylar', ...

  4. python基础数据类型--dict 字典

    字典 字典是python中唯一的映射类型,采用键值对(key-value)的形式存储数据.python对key进行哈希函数运算,根据计算的结果决定value的存储地址,所以字典是无序存储的,且key必 ...

  5. Python中的dict字典的用法

    Python中的字典特点: 速度快,内部使用二分查找的方式 可以用来存储大量的关系型数据 字典是无序的 字典的定义方式: dic = dict(name =”zhangsan”,  age = 19) ...

  6. python数据类型:dict(字典)

    一.字典的简单介绍 字典(dict)是python中唯一的一个映射类型.他是以{}括起来的键值对组成. 语法: {key1:value1,key2:value2......} 注意:key必须是不可变 ...

  7. python数据结构-如何让字典有序

    如何让字典有序 问题举例: 统计学生的成绩和名次,让其在字典中按排名顺序有序显示,具体格式如下 {'tom':(1, 99), 'lily':(2, 98), 'david':(3, 95)} 说明 ...

  8. python数据结构-如何根据字典中值的大小对字典项排序

    如何根据字典中值的大小对字典项排序 问题举例 某班英语成绩以字典形式存储,如何根据成绩高低,计算学生成绩排名 { “tom”:80, "lily":88, "marton ...

  9. python数据结构与算法——字典树

    class TrieTree(): def __init__(self): self.root = {} def addNode(self,str): # 树中每个结点(除根节点),包含到该结点的单词 ...

随机推荐

  1. django入门基础

    首先要说的是django与其他的框架不同,django是一个封装的及其完善的框架,我们使用django也不会像之前写学生系统那样,django操作数据库使用自带的ORM来进行操作,Torando与Fl ...

  2. 获取屏幕宽高度与可视区域宽高度(availWidth、clientWidth、width、innerWidth)

    经常会遇到需要获取屏幕宽度.高度,可视区域宽度.高度等问题,也就常跟这几个打交道,一不小心,还真爱弄混淆了. 先来列举下这几个吧: screen.availHeight.screen.availWid ...

  3. Windows7下远程操作虚拟机

    ⒈分别查看两台物理机的IP地址 ⒉查看虚拟机的IP地址 ⒊两台物理机和虚拟机必须都要处于同一网段,上图中我已经做过了修改(每个节点都要修改,修改见步骤6 ) ⒋打开VMware,编辑虚拟机设置(每个节 ...

  4. vue2.0集成百度UE编辑器,上传图片报错!!!

    我这边配置进去之后,界面加载,文本输入都没有问题,就是上传图片会有问题 这张图, 左边红色框框 就是目录结构咯, 右边红色框框 就是各种网上教程给出的第一个路径配置对吧, 下面的就是绿色 服务器接口配 ...

  5. 邓_php面试【003】——完整版

    php面试题汇总四(基础篇附答案) 1. 什么事面向对象?主要特征是什么? 面向对象是程序的一种设计方式,它利于提高程序的重用性,使程序结构更加清晰.主要特征:封装.继承.多态. 2. SESSION ...

  6. python服务端多进程压测工具

    本文描述一个python实现的多进程压测工具,这个压测工具的特点如下: 多进程 在大多数情况下,压测一般适用于IO密集型场景(如访问接口并等待返回),在这种场景下多线程多进程的区分并不明显(详情请参见 ...

  7. 搞个小项目吧,做一个ppt播放器

    先来两个参考链接,接下来再进行实战 http://www.geek-workshop.com/forum.php?mod=viewthread&tid=1137 http://www.geek ...

  8. python3 第一章 - 简介

    1.什么是python 引用官方的话:Python是一种易于学习,强大的编程语言.它具有高效的高级数据结构,并通过简单而有效的方法来进行面向对象编程.Python的优雅语法和动态类型,以及其解释性质, ...

  9. python_语法糖_装饰器

    什么是高阶函数? -- 把函数名当做参数传给另外一个函数,在另外一个函数中通过参数调用执行 #!/usr/bin/python3 __author__ = 'beimenchuixue' __blog ...

  10. Linux或Window是修改snmp的默认端口

    SNMP默认端口通讯使用 UDP 161,在安装一些监控软件的过程中,常常提示端口被占用等情况,下面说一下如何修改系统的默认SNMP端口 windows修改snmp端口 1 打开services文件 ...