访问字典的值

字典中的 键/值 实际上就是一种映射关系,只要知道了 “键”,就肯定知道 “值”。

>>> my_dict = dict(name = 'zhangsan',other = 'lisi')
>>> my_dict['other']
'lisi'

所以字典中的 “键” 是多么的好用,通过它可以查找值,可以添加值,可以改变值。

既然字典是一种映射关系,所以在字典里也就不需要考虑排序的问题,只要有了 “键” 就可以知道 “值”,那么键 / 值对的位置在哪里也就不需要考虑了,如果你仔细看过上面的例子,你就会发现添加完的值在字典中的显示并不按照它的添加顺序。又因为没有了排序,所以在字典中也没有索引,所以就不存在索引 & 切片。

字典这种键 / 值对的方式存储数据是一种非常高效的方法,查找速度超快,相同的,如果你要在列表中查找一个值,需要从头开始一个个的找,直到找到了指定的索引值,但是在字典中,直接就可以通过 “键” 找到 “值”,小规模数据的时候这种好处可能不显,当存储大规模数据的时候,这种好处是相当明显的。

字典的基本操作

下面我用一些实例来依次演示字典中的基本操作:

>>> my_dict = {'name':'rocky','like':'python','age':23}
>>> len(my_dict) #返回字典中键 / 值对的数量
3
>>> my_dict['age'] #返回字典中的键值
23
>>> my_dict['like'] = 'C ++' #改变字典中的键值
>>> my_dict
{'age': 23, 'name': 'rocky', 'like': 'C ++'}
>>> del my_dict['like'] #删除指定的键 / 值对
>>> my_dict
{'age': 23, 'name': 'rocky'}
>>> 'like' in my_dict #检查字典中是否含有指定键的项
False

字典的方法

与前面所讲述的其它对象类型相似,字典这个对象类型也有一些能够实现对其操作的方法。

1.clear

clear 清除字典中所有的元素,得到的是空的字典。

>>> my_dict = {'name':'rocky','like':'python'}
>>> my_dict.clear()
>>> my_dict
{}
>>> del my_dict
>>> my_dict
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'my_dict' is not defined

上面的例子我们可以看出 clear 和 del 的区别很大,clear 是将字典清空,得到空字典,而 delete 是将字典删除,直接从内存中去掉。

2. get & setdefault

这两个是跟键 / 值对相关的方法,get 方法就是要得到字典中某个 “键” 的 “值”,那么这就有人要说,不是上面的时候我们已经讲过直接查就行吗?在这里的 get 和之前说的还不太一样,这里的 get 稍微宽松一些,如果想要查的值不存在,get 不会有啥反应,而之前说的方法会报错。

>>> my_dict = {'name':'rocky','like':'python'}
>>> my_dict.get('name')
'rocky'
>>> my_dict.get('age')
>>> my_dict['age']
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
KeyError: 'age'

setdefault 也是用来查找字典中某个 “键” 的 “值”,如果查找的 “键” 存在的话就正常输出,如果不存在的话,就在字典中加入这个键 / 值对。

>>> my_dict = {'name':'rocky','like':'python'}
>>> my_dict.setdefault('like')
'python'
>>> my_dict.setdefault('age','')
''
>>> my_dict
{'name': 'rocky', 'like': 'python', 'age': ''}

3.items & keys & values

这是字典的 3 个方法,它们之间有相似之处,很简单,请看下面的实例:

>>> my_dict = {'name':'rocky','like':'python'}
>>> my_d = my_dict.items()
>>> my_d
dict_items([('name', 'rocky'), ('like', 'python')])
>>> my_k = my_dict.keys()
>>> my_k
dict_keys(['name', 'like'])
>>> my_v = my_dict.values()
>>> my_v
dict_values(['rocky', 'python'])

4.pop & popitem

pop 和 popitem 是字典中的删除操作。

pop 是以字典的 “键” 为参数,删除指定的键 / 值对,pop 中的参数不能省略且如果删除字典中没有的键 / 值对,会报错。

>>> my_dict = {'name':'rocky','like':'python'}
>>> my_dict.pop('name')
'rocky'
>>> my_dict
{'like': 'python'}
>>> my_dict.pop()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: pop expected at least 1 arguments, got 0
>>> my_dict.pop('age')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
KeyError: 'age'

popitem 和 pop 有相似之处,但是 popitem 不用写参数,但是它删除的不是最后一个,因为我们说过字典没有顺序,所以 popitem 是随机删除一个,至于删除谁,完全看命。

5.update

update 就是更新字典,参数可以是字典或者某种可迭代的对象,至于什么是可迭代这里你可以先知道这么个词,之后我们会说到,它的返回值是 None,你也可以理解成没有返回值。

>>> my_dict = {'name':'rocky','like':'python'}
>>> first = {'age':23}
>>> my_dict.update(first)
>>> my_dict
{'name': 'rocky', 'like': 'python', 'age': 23}
>>> first
{'age': 23}

Python 字典方法的更多相关文章

  1. python字典方法

    本文参考自<python基础教程 (第二版)> 操作 语法 举例 结果 建立字典 dict() 1.以关键字参数建立字典 2.以其他映射作为参数建立字典 1.d = dict(name=' ...

  2. Python字典方法总结

    1.清空字典中元素清空,dict变为{} L.clear()-> None.  Remove all items from L 1 2 3 4 >>> L ={'shaw':2 ...

  3. Python字典方法copy()和deepcopy()的区别

    from copy import deepcopy # import deepcopy模块 d = {} d['name'] = ['black', 'guts'] # d = {'name': [' ...

  4. python字典copy()方法

    python 字典的copy()方法表面看就是深copy啊,明显独立 d = {'a':1, 'b':2} c = d.copy() print('d=%s c=%s' % (d, c)) Code1 ...

  5. Python 字典(Dictionary) get()方法

    描述 Python 字典(Dictionary) get() 函数返回指定键的值,如果值不在字典中返回默认值. 语法 get()方法语法: dict.get(key, default=None) 参数 ...

  6. Python 字典(Dictionary) setdefault()方法

    描述 Python 字典(Dictionary) setdefault() 函数和get()方法类似, 如果键不已经存在于字典中,将会添加键并将值设为默认值. 语法 setdefault()方法语法: ...

  7. python 字典内置方法get应用

    python字典内置方法get应用,如果我们需要获取字典值的话,我们有两种方法,一个是通过dict['key'],另外一个就是dict.get()方法. 今天给大家分享的就是字典的get()方法. 这 ...

  8. Python 字典(Dictionary) has_key()方法

    描述 Python 字典(Dictionary) has_key() 函数用于判断键是否存在于字典中,如果键在字典dict里返回true,否则返回false. 语法 has_key()方法语法:dic ...

  9. Python 字典 fromkeys()方法

    Python 字典 fromkeys() 方法用于创建一个新的字典,并以可迭代对象中的元素分别作为字典中的键,且所有键对应同一个值,默认为None. fromkeys() 方法语法: 1 dict.f ...

随机推荐

  1. 【转】Mybatis源码解读-设计模式总结

    原文:http://www.crazyant.net/2022.html?jqbmtw=b90da1&gsjulo=kpzaa1 虽然我们都知道有26个设计模式,但是大多停留在概念层面,真实开 ...

  2. 08-HTML-框架标签

    <html> <head>  <title>框架标签学习</title>  <meta charset="utf-8"/> ...

  3. ICML 2018 | 从强化学习到生成模型:40篇值得一读的论文

    https://blog.csdn.net/y80gDg1/article/details/81463731 感谢阅读腾讯AI Lab微信号第34篇文章.当地时间 7 月 10-15 日,第 35 届 ...

  4. Python运维开发:运算符与数据类型(二)

    python对象的相关术语: python程序中保存的所有数据都是围绕对象这个概念展开的: 程序中存储的所有数据都是对象 每个对象都有一个身份.一个类型和一个值 例如,school='MaGe Lin ...

  5. (后端)安装mongodb以及设置为windows服务 详细步骤(转)

    1.在data文件夹下新建一个log文件夹,用于存放日志文件,在log文件夹下新建文件mongodb.log 2.在 D:\mongodb文件夹下新建文件mongo.config,并用记事本打开mon ...

  6. Python笔记(十七):生成器

    (一)生成器(Generator) Python生成器是创建迭代器的简单方法.简单来说,生成器是一个函数,它返回一个我们可以迭代的对象(迭代器)(一次一个值). 因为下面会用到列表生成式,这里先说明下 ...

  7. 线程ThreadDemo04

    package day190109; public class 线程ThreadDemo04 { public static void main(String[] args) throws Inter ...

  8. 用好lua+unity,让性能飞起来——luajit集成篇/平台相关篇

    luajit集成篇 大家都知道luajit比原生lua快,快在jit这三个字上. 但实际情况是,luajit的行为十分复杂.尤其jit并不是一个简单的把代码翻译成机器码的机制,背后有很多会影响性能的因 ...

  9. 文件服务器HFS

    用途:用于文件共享(类似FTP) 官网:http://www.rejetto.com/hfs/?f=ss 优点:比起apache,它有界面方便查看当前正连接的主机 如果在内网环境下进行文件共享的话,可 ...

  10. python3使用selenium + Chrome基础操作代码

    selenium是Python的第三方库,使用前需要安装.但是如果你使用的是anaconda,就可以省略这个步骤,为啥?自带,任性. 安装命令: pip install selenium (一)使用s ...