1.字典推导
字典推导可以从任何以键值对为元素的可迭代对象中构建出字典。
dict_codes = [(86, 'china'), (91, 'india'), (55, 'brazil')]
country_code = {country: code for code, country in dict_codes}
print(country_code)
country_code_1 = {code: country.upper() for country, code in country_code.items() if code < 66}
print(country_code_1)
上段代码中,一个承载着成对数据的列表,可以直接用于字典的构建,在字典推导表达式的for循环中要注意顺序的对应。
2.使用setdefault处理找不到的键
当字典d[k]不能找到正确的键的时候,Python会抛出异常。这时我们可以使用方法setdefault来处理找不到的键。
import sys
import re
WORD_RE = re.compile(r'\w+')
index = {}
with open(sys.argv[1], encoding='utf-8') as fp:
for line_no, line in enumerate(fp, 1):
for match in WORD_RE.finditer(line):
word = match.group()
cloumn_no = match.start()+1
location = (line_no, cloumn_no)
index.setdefault(word, []).append(location)
for word in sorted(index, key=str.upper()):
print(word, index[word])
setdefault(keyname, value)中,使用指定的键返回项目的值。如果键不存在,则插入这个具有指定值的键。其中,value是可选。如果键存在,则此参数无效。如果键不存在,则此值将成为键的值。默认值 None。此外,在正则表达式中,group()用来提出分组截获的字符串,()用来分组。
3.字典的变种
这里介绍collections模块中几个其他的映射类型。
(1)collections.OrderedDict:这个类型在添加键的时候会保持顺序,因此键的迭代次序总是保持一致。其中的popitem()方法默认删除并返回的是字典中的最后一个元素。
(2)collections.ChainMap:这个类型可以容纳数个不同的映射对象,在进行键查找操作时,这些对象会被当做一个整体被逐个查找,直到键被找到为止。
(3)collections.Counter:这个类型会给键准备一个整数计数器,每次更新一个键时都会增加这个计数器。
ct = collections.Counter('askdjasdjalaskdj')
print(ct)
4.不可改变的映射类型
标准库里所有的的映射类型都是可变得,但有时你会有这样的需求,比如不让用户错误的修改某个映射。这里就要运用到types中的MapplingProxyType类。如果给这个类一个映射,他返回的是一个只读的映射视图。但这个视图是动态的,一旦原映射发生了改变,这个动态视图也会发生改变。
from types import MappingProxyType
d = {1:'A'}
d_proxy = MappingProxyType(d)
print(d)
对d进行改变,d_proxy会发生变化,但我们不能修改d_proxy。