《Python3程序开发指南》

映射:键-值数据项的组合

Python3支持两种无序的映射类型:内置的dict类型、标准库中的collections.defaultdict类型。

Python3.1中引入了有序的映射类型:collections.OrderedDict,与内置dict有相同的方法和属性,但在存储数据时以插入顺序进行。

键:可哈希运算的对象的对象引用;值:任意类型对象的对象引用

使用字典字面值创建
>>> d1=dict({"id":1948,"name":"Washer","size":3})
>>> d1
{'id': 1948, 'name': 'Washer', 'size': 3} 使用关键字参数创建
>>> d2=dict(id=1948,name="Washer",size=3) 从序列中创建,d4中的zip()函数返回一个元组列表
>>> d3=dict([("id",1948),("name","Washer"),("size",3)])
>>> d4=dict(zip(("id","name","dize"),(1948,"Washer",3))) 从字典字面值创建
>>> d5={"id":1948,"name":"Washer","size":3}

  迭代:

>>> for item in d1.items():
print item[0],item[1] id 1948
name Washer
size 3 第二种方法
>>> for key,value in d1.items():
print key,value id 1948
name Washer
size 3

  根据字典的值进行迭代

>>> for key in d1.keys():
print key >>> for key in d1:
print key >>> for value in d1.values():
print value

  字典方法

d.clear()  
d.copy() 浅拷贝 
d.fromkeys(s,v) 返回一个dict,该字典的键为序列s中的项,值为None或v中的值(若给定了参数v) 
d.get(k) 返回 键k对应的value,如果k不存在,返回None
d.get(k,v) 返回 键k对应的value,如果k不存在,返回v
d.items() 返回d中的(key,value)对 
d.keys()  
d.pop(k) 返回k对应的value,并删除键为k的项,若没有产生keyError异常 
d.pop(k,v) 返回k对应的value,并删除键为k的项,若没有则返回v
d.popitem() 返回并删除dict中一个任意的(key,value),如果d为空产生KeyError异常 
d.setdefault(k,v)

同d.get()

不同处:如果k没有在d 中,插入一个键为k,值为None或v(若给定了参数v)

d.update(a)

a中未包含在d中的(key,value)添加到d中

同时在a和d中的键,用a中的value替换d中的value

a:可以是字典、可以使(key,value)对的一个iterable,或关键字参数

d.values() 返回d中所有值 

 字典内涵

两种语法格式:

[keyexpression:valueexpression for key, value in iterable]

[keyexpression:valueexpression for key, value in iterable if condition]

实例一:如果使用字典内涵创建字典,键为当前目录中文件的文件名,值为以字节计数的文件大小

os.listdir()返回传递给函数的路径中包含的文件与目录列表但列表中不会包含"."或".."
os.path.getsize()函数返回给定文件的大小(以字节计数) >>> file_sizes = {name:os.path.getseize(name) for name in os.listdir(".")} >>> file_sizes = {name:os.path.getseize(name) for name in os.listdir(".")
if os.path.isfile(name)}

  

创建反转的目录,比如给定字典d,生成一个新字典,新字典的键是d的值,值是d的键

>>> inverted_d = {v:k for k,v in d.items()}

 

默认字典----collections.defaultdict

与普通字典的区别:默认字典可以对遗失的键进行处理。其他方面与普通字典一样

例如,对于某个字典d,其中不包含键为m的项,x=d[m]会产生异常。若d为默认字典,那么如果键为m的项不在字典中,就会创建一个新项,其键为m,值默认,并返回新建的项。

创建默认字典:创建默认字典时,可以传入一个工厂函数,调用工厂函数时,将返回某种特定类型的对象。对默认字典调用工厂函数时,将为遗失的键创建默认值。

Python所有的内置类型都可以用作工厂函数,比如,数据类型str可以作为函数str()进行调用,将返回一个空字符串对象

>>> import collections
>>> words = collections.defaultdict(int)
>>> x = words["xyz"]
>>> x
0
>>> words
defaultdict(<type 'int'>, {'xyz': 0})
>>>

  

有序字典---collections.OrderedDict

以数据项插入的顺序进行存储,python3.1引入

有序字典在创建时,如果接收了无序的dict或关键字参数,则数据项顺序将是任意的。原因:在底层,python使用无序的dict传递关键字参数。使用update()方法时也有类似效果。

但如果在创建时,传递键-值对构成的元组列表,则顺序得以保留。

创建有序字典
>>> import collections
>>> d = collections.OrderedDict([('z',4),('e',1),('a',4)])
>>> d
OrderedDict([('z', 4), ('e', 1), ('a', 4)]) 递增式创建更常见
>>> tasks = collections.OrderedDict()
>>> tasks[1] = "Jim"
>>> tasks[2] = "Jan"
>>> tasks[3] = "Tom"
>>> tasks
OrderedDict([(1, 'Jim'), (2, 'Jan'), (3, 'Tom')])

 生成排序字典可通过 d = collections.OrderedDict(sorted(d.items()))来实现,但对于重新加入新的项再排序,则需要一定的开销。

 

 

Python字典--笔记的更多相关文章

  1. Python字典笔记

    1.字典是Python中=唯一的映射类型.映射类型对象里哈希值(键,key)和只指向的对象(值,value)是一对多的关系,一个字典是可变的,是一个容器类型.字典类型和序列类型(元组,列表)的不同在于 ...

  2. python学习笔记整理——字典

    python学习笔记整理 数据结构--字典 无序的 {键:值} 对集合 用于查询的方法 len(d) Return the number of items in the dictionary d. 返 ...

  3. python学习笔记(一)元组,序列,字典

    python学习笔记(一)元组,序列,字典

  4. 【python学习笔记】4.字典:当索引不好用时

    [python学习笔记]4.字典:当索引不好用时 字典是python中唯一内建的map类型 创建: key可以为任何不可改变的类型,包括内置类型,或者元组,字符串 通过大括号: phonebook={ ...

  5. Python学习笔记3-Python元组、数组、字典集合的操作

    在Python中数组中的每一项可以是不同的数据类型 元组:只能读不能写的数组 aTuple=(1,'abc','tmc',79.0,False) print aTuple[1:3] print typ ...

  6. Python学习笔记(七)—字典的学习

    总结内容: 1.字典的定义 2.字典的好处 3.字典的增删改查 4.字典常用方法及内置函数 5.字典的多层嵌套 6.字典的循环 7.字典小练习 1.字典的定义 字典是另一种可变容器模型,且可存储任意类 ...

  7. python学习笔记:第五天( 字典)

    Python3 字典 字典是另一种可变容器模型,且可存储任意类型对象. 字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号({})中 ,格 ...

  8. Python学习笔记(字典)

    今天学习一个python中的基本类型--字典(dictionary) 字典这种数据结构有点像我们平常用的通讯录,有一个名字和这个名字对应的信息.在字典中,名字叫做“键”,对应的内容信息叫做“值”.字典 ...

  9. [Python爬虫笔记][随意找个博客入门(一)]

    [Python爬虫笔记][随意找个博客入门(一)] 标签(空格分隔): Python 爬虫 2016年暑假 来源博客:挣脱不足与蒙昧 1.简单的爬取特定url的html代码 import urllib ...

随机推荐

  1. underscorejs-where学习

    2.7 where 2.7.1 语法: _.where(list, predicate) 2.7.2 说明: 对list集合的每个对象依次与predicate对象进行匹配,返回一个数组(数组为匹配成功 ...

  2. 织梦安装过后出现"...www/include/templets/default/index.htm Not Found!"

    在织梦网站搬家之后再整站更新,往往会遇到访问首页的时候出现www/include/templets/default/index.htm Not Found!,这个问题我遇到过两次,都是这样解决的: 进 ...

  3. 3D touch 的 应用 --备用

    在iPhone 6s和iPhone 6s Plus中Apple引入了3D Touch技术.3D Touch的触控技术,被苹果称为新一代多点触控技术.其实,就是此前在Apple Watch上采用的For ...

  4. java的类加载机制

    1.概述 Class文件由类装载器装载后,在JVM中将形成一份描述Class结构的元信息对象,通过该元信息对象可以获知Class的结构信息:如构造函数,属性和方法等,Java允许用户借由这个Class ...

  5. UML问题

    1.在创建协作图时需要先确定参与者,而协作图的工具栏里是没有Actor的,这是需要先new Actor,然后把其拖动到工作区:实验过程中发现必须创建在用例视图下,若是创建在逻辑试图下那么根本无法继续操 ...

  6. ViewPage和ActionBar打造滑动视图

    滑动效果非常流畅,可以将页签放置到ActionBar上,点击页签可以切换ViewPage,滑动ViewPage会同步更显Tabs. main.xml <?xml version="1. ...

  7. 处理鼠标响应事件(最简单控件 good)

    贴下代码: #ifndef MYWIDGET_H#define MYWIDGET_H #include <QWidget>#include <QtGui>#include &l ...

  8. Spring Data Elasticsearch

    项目清单   elasticsearch服务下载包括其中插件和分词   http://download.csdn.net/detail/u014201191/8809619   项目源码   资源文件 ...

  9. HDOJ(HDU) 1799 循环多少次?(另类杨辉三角)

    Problem Description 我们知道,在编程中,我们时常需要考虑到时间复杂度,特别是对于循环的部分.例如, 如果代码中出现 for(i=1;i<=n;i++) OP ; 那么做了n次 ...

  10. 乱译文档--Musca介绍

    胡乱翻译的,信,达,雅只能到达的水平.发现错误的话望留言好修改. 原文地址:http://aerosuidae.net/musca.html aerosuidae.net Musca 果蝇 A sim ...