.Net程序员之Python基础教程学习----字典的使用 [Third Day]

    今天学习了字典的使用, 所谓的字典其实就是键值对数据, 一个字典里面有唯一的Key对应一个value,Key是唯一的,Value不唯一. 在.net添加相同的Key会报错,在Python,若出现相同的Key,后面Key的value将会覆盖前面的数据.

   一.字典的基本用法.

    1.字典的创建: 字段的创建格式是{key:Value,Key:Value},也可以通过,dict函数转换。

Note:key的顺序按照字符串从小到大排序;如果声明字典的时候有相同的Key,取最后一个。(有别于.net)

    

>>> dic1={‘Name‘:‘Hardy‘,‘Age‘:24}
>>> dic1
{‘Age‘: 24, ‘Name‘: ‘Hardy‘}

>>> imtes=[(‘Name‘,‘Frank‘),(‘Age‘,23)]
>>> dic = dict(imtes);
>>> dic
{‘Age‘: 23, ‘Name‘: ‘Frank}

>>> dic2={‘Name‘:‘Hardy‘,‘Age‘:24,‘Name‘:‘Frank‘}  #第一个被覆盖了>>> dic2{‘Age‘: 24, ‘Name‘: ‘Frank‘}

      2.字典的基本使用

    

>>> imtes=[(‘Name‘,‘Frank‘),(‘Age‘,23)]
>>> dic = dict(imtes);
>>> dic
{‘Age‘: 23, ‘Name‘: ‘Frank‘}
>>> len(dic)  #长度
2
>>> ‘Age‘ in dic #判断是否有Key存在
True
>>> dic[‘Age‘] = 22 #修改值
>>> dic
{‘Age‘: 22, ‘Name‘: ‘Frank‘}
>>> del dic[‘Age‘] #删除某个元素
>>> dic
{‘Name‘: ‘Frank‘}

3.字典的格式化.
     在前面合计将了两种格式化,一种通过元组格式化数据,还有一种是通过template模板来使用字典格式化数据. 下面来解释字典格式化数据.

    

>>> workMsg = {‘Frank‘:‘Coder‘,‘Nancy‘:‘HR‘,‘Vincent‘:‘Project Manager‘}
>>> ‘Frank is the %(Frank)s‘ %workMsg
‘Frank is the Coder‘

   二. 字典内部提供方法的使用.

    1.Clear方法: 在使用Clear方法的时候大家请看下面三个例子.    

    Note:表面上通过dic={}是清空数据。

第一个案例:dicTestB1和dicTestA1都指向同一个空间。可是对于dicTestA1={}操作,其实是开辟了一个新空间,dicTest1指向了{}对应的空间,所以dicTestB1还是保留原来数据.  

       第二个案例: dicTestB2和dicTestA1指向同一个空间. 可是dicTestA1.clear()是对当前空间清空,没有产生其他新的空间,所以dicTestB2也没有数据了.

       第三个案例: 因为调用了copy()方法,其实在dicTestB3=dicTestA3.copy()时就开辟了新空间,那么dicTestB3和dicTestA3已经毫无相关了,所以dicTestA3任何操作不影响dicTextB3值     

>>> dicTestA1 = {‘Name‘:‘Frank‘}
>>> dicTestB1 = dicTestA1
>>> dicTest1={}
>>> dicTest1
{}
>>> dicTestB1
{‘Name‘: ‘Frank‘}
>>>
>>> dicTestA2={‘Name‘:‘Frank‘}
>>> dicTestB2=dicTestA2
>>> dicTestA2.clear()
>>> dicTestB2
{}
>>>
>>> dicTestA3={‘Name‘:‘Frank‘}
>>> dicTestB3=dicTestA3
>>> dicTestB3 = dicTestA3.copy()
>>> dicTestA3.clear()
>>> dicTestA3={}
>>> dicTestB3
{‘Name‘: ‘Frank‘}

     2.fromkeys: 为字典添加values为空的key.

    

>>> {}.fromkeys([‘Name‘,‘Age‘])
{‘Age‘: None, ‘Name‘: None}}>>> {}.fromkeys([‘Name‘,‘Age‘],‘Unkown‘){‘Age‘: ‘Unkown‘, ‘Name‘: ‘Unkown‘}>>>

3. has_key() 和key in dic一样判断是否包含key
            4. items 和 iteritems: 获取字典元素列表,用于字典的遍历,类是于.net的keyvaluepair<key,value>,后者是通过迭代器实现的.一般来说迭代器的效率更高.

    

>>> workMsg = {‘Frank‘:‘Coder‘,‘Nancy‘:‘HR‘,‘Vincent‘:‘Project Manager‘}
>>> workMsg.items()
[(‘Frank‘, ‘Coder‘), (‘Vincent‘, ‘Project Manager‘), (‘Nancy‘, ‘HR‘)]
>>> list(workMsg.iteritems())
[(‘Frank‘, ‘Coder‘), (‘Vincent‘, ‘Project Manager‘), (‘Nancy‘, ‘HR‘)]
>>> 

     5.keys和iterkeys 以及 values和itervalues 分别实现后去key列表和values列表.

6.pop(key) 和 popitem 以及del 实现对字段元素的删除

7.update(parma) 一个字典更新另一个字典.

三. 总结:

    

         整体来说,字典还是挺简单的. 不过对于里面调用方法的clear()以及update()都是对当前内存的数据进行操作,如果单独通过=来赋值也可以达到更新效果,其实原理是不一样,    =号相当于丢弃以前数据重新在新的内存存储。这个有点类是于我们常常对数据库的数据进行更新,可以通过update来实现,也可以通过delete和add来实现的原理差不多.

    

    

时间: 2024-12-16 19:58:42

.Net程序员之Python基础教程学习----字典的使用 [Third Day]的相关文章

.Net程序员之Python基础教程学习----列表和元组 [First Day]

一. 通用序列操作: 其实对于列表,元组 都属于序列化数据,可以通过下表来访问的.下面就来看看序列的基本操作吧. 1.1 索引: 序列中的所有元素的下标是从0开始递增的. 如果索引的长度的是N,那么所以的范围是-N~N-1之间,超过这个范围就会提示 IndexError:  index out of range >>> greeting ='Hello world' >>> print greeting Hello world >>> print gr

.Net程序员之Python基础教程学习----函数和异常处理[Fifth Day]

   今天主要记录,Python中函数的使用以及异常处理. 一.函数:    1.函数的创建以及调用. def Add(val1,val2): return val1+val2; print Add(1,2) 2. 定义返回多参数的函数,返回的参数以元组的形式返回,可以通过下表索引来获取单个值,下面是获取两数之差和两数之和的函数. 整体上来说还是不错的,在C#中我们一般都用out来实现,多个参数改变返回,不过那样可读性不好. def GetSubAndSum(val1,val2): return

.Net程序员之Python基础教程学习----判断条件与循环[Fourth Day]

    今天学习Python的判断条件与循环操作. 一. 布尔变量: 在学习判断条件之前必须的了解bool变量,在Python中bool变量与C语言比较类似,与.net差别比较大,其中下面集中情况需要记住. False, '', 0, (), [],{},None 为空,而True,12,'hello',[1] 这些普遍都为真. 其实可以简单理解为,无即是false,有既是true >>> bool(True) True >>> bool(0) False >&g

.Net程序员之Python基础教程学习----字符串的使用 [Second Day]

     在The FirstDay 里面学习了列表的元组的使用,今天开始学习字符串的使用.字符串的使用主要要掌握,字符串的格式化(C语言中我们应该都知道,Python和C语言差别不大),字符串的基本操作(Join,Split,Replace等和.net里面的也有很多相似点) 一.字符串的基本操作     1.字符串格式化认识: 字符串的格式化用%隔开与C语言一样.赋值也是用%(val1,val2)来传递,其实就是用元组来传递格式化数据. Note: values元素的个数以及格式必须与格式化字

Python基础教程学习:深入 Python iter() 方法

今天我们来介绍下Python基础教程学习之iter() 方法另外的用法.据说很少有人知道这个用法! 一.上代码.学用法 我们都比较熟悉 iter(obj),会返现一个迭代器,如果 obj 不是可迭代对象,则会报错.但其实如果仔细看官方文档,会发现 iter() 方法其实是接受两个参数的,文档说明如下 iter(object[, sentinel]) sentinel 英文翻译为 哨兵. sentinel 参数是可选的,当它存在时,object 不再传入一个可迭代对象,而是一个可调用对象,通俗点说

&lt;&lt;Python基础教程&gt;&gt;学习笔记之|第01章|基础知识

本学习笔记主要用要记录下学习<<Python基础教程>>过程中的一些Key Point,或自己没怎么搞明白的内容,可能有点杂乱,但比较实用,查找起来也方便. 第01章:基础知识 ------ Jython:      Python的Java实现,运行在JVM中,相对稳定,但落后于Python,当前版本2.5,在TA(Python+Robot)会用到 IronPython:  Python的C#实现,运行在Common Language Runtime,速度比Python要快 >

&lt;&lt;Python基础教程&gt;&gt;学习笔记 | 第09章 | 魔法方法、属性和迭代器

这一章,有点抽象,看着有点蛋疼! 双下划线__future__或单下划线有特殊含义,在Python中,这些名字的集合称为魔法方法:最重要的是__init__和一些处理访问对象的方法,这些方法允许你创建自己的序列或者是映射. ------ 准备工作: 将__metaclass__=type放在模块的最开始位置,以确保类时最新式的.考虑下面两个类 class NewStyle(object): more_code_here class OldStyle: more_code_here 如果文件以__

&lt;&lt;Python基础教程&gt;&gt;学习笔记 | 第08章 | 异常

------ 什么是异常:Python用异常对象(exception object)来表示异常情况.如果异常信息未被处理或捕捉. 程序就会用回潄来终止执行 >>> 1/0 Traceback (most recent call last): #Traceback: 一种错误信息 File "<stdin>", line 1, in ? ZeroDivisionError: integer division or modulo by zero 每个异常都是一

&lt;&lt;Python基础教程&gt;&gt;学习笔记 | 第07章 | 更加抽象

------ Python:面向对象的编程语言,多态,封装,继承三个主要特性 多态:来自希腊语,意味着有多种形式. >>> from random import choice >>> x = choice(['Hello,World!',[1,2,'e','e',4]]) >>> x.count('e') 1 任何不知道对象到底是什么类型,但又要对对象做的什么的时候,就要用到多态 >>> 1+2 3 >>> 'hot