关于python中字典的一些总结
1、 获取字典中的值,但是无异常
当在字典中取值的时候,可以使用如下两种方式:
>>> d = {'name':'kel'}
>>> d
{'name': 'kel'}
>>> d['name']
'kel'
>>> d.get('name')
'kel'
>>> d.get('not')
>>> d.get('not','not exist')
'not exist'
>>> d['not']
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
KeyError: 'not'
一种是使用直接key的方式来进行读取,也就是dict[key],当key不存在的时候,会发生KeyError的异常。
另外一种是使用get的方式,当使用get方法的时候,默认情况下返回的None,如果key存在,那么就会返回这个key对应的值。
当需要在获取这个键的时候,然后删除这个项,那么可以使用pop方法,在使用pop方法的时候,使用默认值,从而不会在键不存在的时候出现异常,如下所示:
>>> d
{'name': 'kel'}
>>> d.pop('kel')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
KeyError: 'kel'
>>> d.pop('kel','key is not exist')
'key is not exist'
>>> d.pop('name')
'kel'
pop使用之后,会返回这个键所对应的值。
在使用这种默认值的机制下,基本使用的是如下的方法:
>>> d = {'name':'kel'}
>>> if 'name' in d:
... print d['name']
... else:
... print 'not found'
...
kel
也就是引入了in的测试,判断这个key是不是在dict中,如果在,那么返回值,如果不在,那么返回默认值。
2、给字典增加一个条目
setdefault方法主要是用来设置字典的键值,当一个键存在的时候,直接使用已经存在的值,当键不存在的时候,那么就添加一个值。
>>> d
{'name': 'kel'}
>>> d.setdefault('kel','person')
'person'
>>> d
{'kel': 'person', 'name': 'kel'}
>>> d.setdefault('kel','animal')
'person'
>>> d
{'kel': 'person', 'name': 'kel'}
当开始未存在键kel的时候,那么就会添加一个键值对;当后面存在键kel的时候,那么就会取得此值。
最经典的使用setdefault方法如下:
>>> d.setdefault('abc',[]).append('123')
>>> d
{'kel': 'person', 'name': 'kel', 'abc': ['123']}
当字典中的值是列表的时候,那么就可以使用方法d.setdefault(somekey,[]).append(somevalue)
3、创建字典
创建字典主要有三种方式:
第一种方式:使用命名参数来创建--这种情况下不适合存在不符合变量命名的键,和存在关键字的键,例如for等关键字
>>> d = dict(name='kel',age=32)
>>> d
{'age': 32, 'name': 'kel'}
第二种方式:
>>> d = {'name':'kel','age':32}
>>> d
{'age': 32, 'name': 'kel'}
第三种方式:创建一些一些字典具有默认值的时候使用
>>> d = dict.fromkeys(('age','name') ,None)
>>> d
{'age': None, 'name': None}
创建字典最好的方法是使用dict内建函数来使用,dict返回一个完全独立于d的拷贝,就象d.copy一样,当d不是一个字典,是一个数对(key,value)的序列时,ditc(t)依然是可以创建一个字典。
4、将列表中的元素交替的作为字典的键和值
使用最简单的方式就是使用zip和切片,从而得到字典的键和值,如下所示:
list1 = [1,2,3,4,5]
def dictFromList(keysAndValues):
return dict(zip(keysAndValues[::2],keysAndValues[1::2]))
print dictFromList(list1)
此方法主要是将列表进行切片,从而得到奇数的key和偶数的value,再使用zip函数,从而得到一个序列对,从而转换为字典。
def pairwise(iterable):
itnext =iter(iterable).next
while True:
yield itnext(),itnext()
def dictFromSequence(seq):
return dict(pairwise(seq))
有可以使用生成器的方法,在每次进行跌倒的时候,得到序列的两个元素,两个元素作为一个序列对,然后进行转换为字典,从而在这种方法中,可以提高性能。
注意上面的例子中,将一个迭代器绑定到了本地变量,从而在每次取值的时候,只要使用本地变量即可。
5、获取一个字典的子集
def sub_dict(somedict,somekeys,default=None):
return dict([(k,somedict.get(k,default)) for k in somekeys]) def sub_dict_remove(somedict,somekeys,default=None):
return dict([(k,somedict.pop(k,default)) for k in somekeys])
在两个方法中,使用的都是列表解析,在使用生成器的时候效率更高,只要将中括号修改的圆括号即可。
第一个方法,不会修改原来的字典;第二个方法会将原来的字典存在的键进行删除。
在上面的两个方法中,可以增加一些判断的方法,在列表解析或者生成器里添加 if k in somedict,从而可以在没有键的时候,忽略这个键
6、 反转字典
d = {'a':5,'b':6,'c':7}
print dict(izip(d.itervalues(),d.iterkeys()))
主要就是使用itertools中的izip来提高速度,从而来反转字典
7、一个键对应多个值
当一个键需要对应多个值的时候,例如一个列表,可以使用setdefault方法:
>>> d1 = {}
>>> d1
{}
>>> d1.setdefault('key',[]).append(1)
>>> d1
{'key': [1]}
>>> d1.setdefault('key',[]).append(2)
>>> d1
{'key': [1, 2]}
当值不能重复的时候,可以使用set集合
>>> d3.setdefault('key',set()).add(1)
>>> d3
{'key': set([1])}
>>> d3.setdefault('key',set()).add(2)
>>> d3
{'key': set([1, 2])}
8、 字典的交集和并集
当只考虑字典的键的时候,那么这个时候使用字典的交集和并集,可以将他们转换为set之后,然后进行相关操作,
>>> phones = {1:1,2:2}
>>> addresses = {1:1,3:3}
>>> for name in set(phones).intersection(addresses):
... print name,phones[name],addresses[name]
...
1 1 1
交集的时候使用itersection当使用并集的时候使用union。
9、使用字典做到case语法
animals = []
number_of_felines = 0 def deal_with_a_cat():
global number_of_felines
print 'meow'
animals.append('feline')
number_of_felines += 1 def deal_with_a_dog():
print 'bar'
animals.append('canine') def deal_with_a_bear():
print 'wathch our for the *HUG*'
animals.append('usrine') tokenDICT = { #使用字典,来绑定各个方法
'cat':deal_with_a_cat,
'dog':deal_with_a_dog,
'bear':deal_with_a_bear,
}
#simulate,from files to read a word
words = ['cat','bear','cat','dog']
for word in words:
'find the word method and call it'
tokenDICT[word]() #根据键来调用具体的方法
nf = number_of_felines
print 'we met %d feline %s ' % (nf,'s'[nf==1:])
print 'the animals we met were:',' '.join(animals)
构建一个字典,用字符串或者其他对象为键,以被绑定的方法,函数或者其他的可调用体作为值,在每一步中,都用键来作为可调用值,来进行具体方法的调用,从而可以形成case语句的选择作用。
关于python中字典的一些总结的更多相关文章
- Python中字典和集合
Python中字典和集合 映射类型: 表示一个任意对象的集合,且可以通过另一个几乎是任意键值的集合进行索引 与序列不同,映射是无序的,通过键进行索引 任何不可变对象都可用作字典的键,如字符串.数字.元 ...
- python中字典的循环遍历的两种方式
开发中经常会用到对于字典.列表等数据的循环遍历,但是python中对于字典的遍历对于很多初学者来讲非常陌生,今天就来讲一下python中字典的循环遍历的两种方式. 注意: python2和python ...
- python中字典排序,列表中的字典排序
python中字典排序,列表中的字典排序 一.使用python模块:operator import operator #首先要导入模块operator x = {1:2, 3:4, 4:3, 2:1, ...
- python中字典的使用
python中的字典的特性: 在字典中的元素是散列存放的,没有顺序, 在进行增删改查的时候使用字典中需要的关键字(key)即可. 一: 创建字典 1)直接定义一个: dict = {'ob1':'co ...
- python接口自动化(九)--python中字典和json的区别(详解)
简介 这篇文章的由来是由于上一篇发送post请求的接口时候,参数传字典(dict)和json的缘故,因为python中,json和dict非常类似,都是key-value的形式,为啥还要这么传参,在群 ...
- python中字典和json的区别
python中,json和dict非常类似,都是key-value的形式,而且json.dict也可以非常方便的通过dumps.loads互转 定义 python中,json和dict非常类似,都是k ...
- python中字典的用法
一,字典的简单介绍概念: 字典(dict)是python中唯一的一个映射类型.他是以{ }括起来的键值对组成. 在dict中key是 唯一的. 在保存的时候, 根据key来计算出一个内存地址. 然后将 ...
- Python中字典和集合的用法
本人开始学习python 希望能够慢慢的记录下去 写下来只是为了害怕自己忘记. python中的字典和其他语言一样 也是key-value的形式 利用空间换时间 可以进行快速的查找 key 是唯一的 ...
- Python中字典的相关操作
1. Python类似于Java中的哈希表,只是两种语言表示的方式是不一样的,Python中的字典定义如下: 在Python中是一种可变的容器模型,它是通过一组键(key)值(value)对组成,这种 ...
- Python中字典合并的四种方法
字典是Python语言中唯一的映射类型.映射类型对象里哈希值(键,key)和指向的对象(值,value)是一对多的的关系,通常被认为是可变的哈希表.字典对象是可变的,它是一个容器类型,能存储任意个数的 ...
随机推荐
- .NET 压缩解压库发布,支持进度查看
刚发布了一个 .net压缩解压库,基于SharpZipLib开发 ,支持进度查看,支持路径保持与否. CL.IO.Zip 是一个基于SharpZipLib的一个压缩和解压的类库,提供给用户在.net环 ...
- eclipse使用replace命令替换整个project/workspace的某个字符串
比如说为了在调试的时候方便,我的应用程序中有很多System.out.println() 调试好了,要发布了,如何把这些一次性注释掉呢?见下图
- SGU 106 The equation 扩展欧几里得好题
扩展欧几里得的应用……见算法竞赛入门经典p.179 注意两点:1.解不等式的时候除负数变号 2.各种特殊情况的判断( a=0 && b=0 && c=0 ) ( a=0 ...
- 笔记三、apache搭建gitweb【转】
参考文章: http://www.latelee.org/using-gnu-linux/ubuntu-apache-gitweb.html http://blog.csdn.net/ ...
- js中的cookie使用
在网上找到的资料,收藏一下 function getCookies(name) { var arr = document.cookie.match(new RegExp("(^| )&quo ...
- django 外键 ,django __
data sqlite> select * from author; id name age 1 jim 12 2 tom 11 sqlite> select * from book; i ...
- YTU 2614: A代码完善--系统日期
2614: A代码完善--系统日期 时间限制: 1 Sec 内存限制: 128 MB 提交: 216 解决: 113 题目描述 注:本题只需要提交填写部分的代码,请按照C++方式提交. 已知某操作 ...
- 红黑树、B(+)树、跳表、AVL等数据结构,应用场景及分析,以及一些英文缩写
在网上学习了一些材料. 这一篇:https://www.zhihu.com/question/30527705 AVL树:最早的平衡二叉树之一.应用相对其他数据结构比较少.windows对进程地址空间 ...
- aptana studio 3支持jquery
首先要说的一点是,如果你不使用PortableGit,就不要安装,否则New From Template中会缺失大部分模板.至于还有什么缺陷,暂时没测出来,本人也是刚玩aptana studio 3哈 ...
- Node Security
发一个很早之前做的一个小东西-安全管理软件-可以对U盘进行管理,对后台程序进行扫描.分析!