详解Python中映射类型的内建函数和工厂函数


Posted in Python onAugust 19, 2015

1.基本函数介绍

(1)标准类型函数[type()、str()和 cmp()]
        对一个字典调用type()工厂方法,会返回字典类型:“<type 'dict'>”。调用str()工厂方法将返回该字典的字符串表示形式。
        字典是通过这样的算法来比较的:首先是字典的大小,然后是键,最后是值。可是用cmp()做字典的比较一般不是很有用。
 

 算法按照以下的顺序:
首先比较字典长度
        如果字典的长度不同,那么用cmp(dict1, dict2)比较大小时,如果字典dict1比dict2长,cmp()返回正值,如果dict2比dict1长,则返回负值。也就是说字典中的键的个数越多,这个字典就越大,即:len(dict1) > len(dict2) ==> dict1 > dict2。
其次比较字典的键
        如果两个字典的长度相同,那就按字典的键比较。键比较的顺序和keys()方法返回键的顺序相同。(注意: 相同的键会映射到哈希表的同一位置,这保证了对字典键的检查的一致性)。这时,如果两个字典的键不匹配时,对这两个(不匹配的键)直接进行比较。当dict1中第一个不同的键大于dict2中第一个不同的键,cmp()会返回正值。
然后比较字典的值
       如果两个字典的长度相同而且它们的键也完全匹配,则用字典中每个相同的键所对应的值进行比较。一旦出现不匹配的值,就对
这两个值进行直接比较。若dict1比dict2中相同的键所对应的值大,cmp()会返回正值。
完全匹配
       到此为止,即每个字典有相同的长度、相同的键、每个键也对应相同的值,则字典完全匹配,返回 0 值。
(2)映射类型相关的函数
 dict()

       工厂函数被用来创建字典,如果不提供参数会生成空字典。当容器类型对象做为一个参数传递给方法 dict(),如果参数是可以迭代的,即一个序列或是一个迭代器或是一个支持迭代的对象,那每个可迭代的元素必须成对出现。在每个值对中,第一个元素是字典的键、第二个元素是字典中的值。

>>> dict(zip(('x', 'y'), (1, 2))) 
  {'y': 2, 'x': 1} 
  >>> dict([['x', 1], ['y', 2]]) 
  {'y': 2, 'x': 1} 
  >>> dict([('xy'[i-1], i) for i in range(1,3)]) 
  {'y': 2, 'x': 1}

        如果输入参数是(另)一个映射对象,比如一个字典对象,对其调用dict()会从存在的字典里复制内容来生成新的字典。新生成的字典是原来字典对象的浅复制版本,它与用字典的内建方法copy()生成的字典对象是一样的。但是从已存在的字典生成新的字典速度比用copy()方法慢,推荐使用copy()。
len()
       内建函数len()很灵活,它可用在序列、映射类型和集合上。对字典调用 len(),它会返回所有元素(键-值对)的数目。
hash()
       内建函数hash()本身并不是为字典设计的方法,但它可以判断某个对象是否可以做一个字典的键。将一个对象作为参数传递给 hash(),会返回这个对象的哈希值。 只有这个对象是可哈希的,才可作为字典的键 (函数的返回值是整数,不产生错误或异常)。如果用比较操作符来比较两个数值,发现它们是相等的,那么即使二者的数据类型不同, 它们也会得到相同的哈希值。如果非可哈希类型作为参数传递给hash()方法,会产生TypeError错误,因此如果使用这样的对象作为键给字典赋值时会出错。

2.映射类型的内建函数和工厂函数使用实例

标准类型函数[type(),str()和cmp()]
字典比较算法

>>> dict1 = {}

>>> dict2 = {'host':'earth','port':80}

>>> cmp(dict1,dict2)

-1

>>> dict1['host'] = 'earth'

>>> cmp(dict1,dict2)

-1

>>> dict1['port'] = 80     

>>> cmp(dict1,dict2)

0

>>> dict1['port'] = 'tcp'

>>> cmp(dict1,dict2)

1

>>> dict2['port'] = 'udp'

>>> cmp(dict1,dict2)  

-1

>>> cdict = {'fruits':1}

>>> ddict = {'fruits':1}

>>> cmp(cdict,ddict)

0

>>> cdict['oranges'] = 0

>>> cdict['apples'] = 0    

>>> cmp(cdict,ddict)

1

映射类型相关的函数

dict()

>>> dict(zip(('x','y'),(1,2)))

{'y': 2, 'x': 1}

>>> dict([['x',1],['y',2]]) 

{'y': 2, 'x': 1}

>>> dict([('xy'[i-1],i) for i in range(1,3)])

{'y': 2, 'x': 1}


>>> dict(x=1,y=2)

{'y': 2, 'x': 1}

>>> dict8 = dict(x=1,y=2)

>>> dict8

{'y': 2, 'x': 1}

>>> dict9 = dict(**dict8)

>>> dict9

{'y': 2, 'x': 1}


>>> dict9 = dict8.copy()

>>> dict9

{'y': 2, 'x': 1}


len()

>>> dict2 = {'name':'earth','port':80}

>>> dict2

{'name': 'earth', 'port': 80}

>>> len(dict2)

2

Python 相关文章推荐
动态创建类实例代码
Oct 07 Python
python通过urllib2获取带有中文参数url内容的方法
Mar 13 Python
python实现通过pil模块对图片格式进行转换的方法
Mar 24 Python
部署Python的框架下的web app的详细教程
Apr 30 Python
python opencv实现任意角度的透视变换实例代码
Jan 12 Python
对python3 urllib包与http包的使用详解
May 10 Python
Python中使用pypdf2合并、分割、加密pdf文件的代码详解
May 21 Python
pycharm访问mysql数据库的方法步骤
Jun 18 Python
使用Python Pandas处理亿级数据的方法
Jun 24 Python
用gpu训练好的神经网络,用tensorflow-cpu跑出错的原因及解决方案
Mar 03 Python
Python 阶乘详解
Oct 05 Python
Python实现Matplotlib,Seaborn动态数据图
May 06 Python
详解Python中映射类型(字典)操作符的概念和使用
Aug 19 #Python
Python中字典的基础知识归纳小结
Aug 19 #Python
Python在Windows和在Linux下调用动态链接库的教程
Aug 18 #Python
Python中map,reduce,filter和sorted函数的使用方法
Aug 17 #Python
Nginx搭建HTTPS服务器和强制使用HTTPS访问的方法
Aug 16 #Python
使用Python操作MySQL的一些基本方法
Aug 16 #Python
Python中list列表的一些进阶使用方法介绍
Aug 15 #Python
You might like
php数据结构 算法(PHP描述) 简单选择排序 simple selection sort
2011/08/09 PHP
Zend的MVC机制使用分析(二)
2013/05/02 PHP
完美实现wordpress禁止文章修订和自动保存的方法
2014/11/03 PHP
php表单加入Token防止重复提交的方法分析
2016/10/10 PHP
老生常谈PHP面向对象之解释器模式
2017/05/17 PHP
JavaScript 提升运行速度之循环篇 译文
2009/08/15 Javascript
JQury slideToggle闪烁问题及解决办法
2011/07/05 Javascript
别了 JavaScript中的isXX系列
2012/08/01 Javascript
js综合应用实例简单的表格统计
2013/09/03 Javascript
原始XMLHttpRequest方法详情回顾
2013/11/28 Javascript
js实现通用的微信分享组件示例
2014/03/10 Javascript
JavaScript实现简单图片翻转的方法
2015/04/17 Javascript
js实现简单锁屏功能实例
2015/05/27 Javascript
基于jquery实现人物头像跟随鼠标转动
2015/08/23 Javascript
JS DOMReady事件的六种实现方法总结
2016/11/23 Javascript
浅谈webpack打包过程中因为图片的路径导致的问题
2018/02/21 Javascript
layui-table获得当前行的上/下一行数据的例子
2019/09/24 Javascript
[56:56]VG vs LGD 2019国际邀请赛淘汰赛 胜者组 BO3 第一场 8.22
2019/09/05 DOTA
Python交换变量
2008/09/06 Python
Python写的一个简单监控系统
2015/06/19 Python
Python实现短网址ShortUrl的Hash运算实例讲解
2015/08/10 Python
Python 函数基础知识汇总
2018/03/09 Python
python设定并获取socket超时时间的方法
2019/01/12 Python
python实现BP神经网络回归预测模型
2019/08/09 Python
为什么说python适合写爬虫
2020/06/11 Python
tensorflow/core/platform/cpu_feature_guard.cc:140] Your CPU supports instructions that this T
2020/06/22 Python
css3学习之2D转换功能详解
2016/12/23 HTML / CSS
浅谈基于Canvas的手绘风格图形库Rough.js
2018/03/19 HTML / CSS
UGG英国官方网站:UGG UK
2018/02/08 全球购物
GIVENCHY纪梵希官方旗舰店:高定彩妆与贵族护肤品
2018/04/16 全球购物
介绍一下linux的文件权限
2012/02/15 面试题
初中学校军训方案
2014/05/09 职场文书
党员目标管理责任书
2014/07/25 职场文书
2014年学生会生活部工作总结
2014/11/07 职场文书
开除通知书范本
2015/04/25 职场文书
2019年入党思想汇报
2019/03/25 职场文书