零基础学习python_字典(25-26课)

  今天学到后面的知识,突然发现之前学习到的字典列表啥的都有点忘了,打算补一下之前学到的字典,到时候你看的时候,字符串、列表、字典、元祖这几个没啥顺序,刚开始学的时候了解下方法,当然你可以死记硬背下,后面用到的时候不记得再看也行,熟能生巧嘛!今天主要讲的是字典的方法。

  用相对正式的话来说的话,Python中的字典是python的一种数据结构,它的本质是key和value以及其对应关系的一种集合,一个key可以对应一个多个value。其实看下例子你就很容易理解了。

1、字典的创建(啥东西都得先出生才行吧)

字典的创建有几种方法:

第一种,直接以两个大括号中间以逗号分隔

第二种,通过dict这个对象直接赋值

第三种,通过dict对象对元祖和列表进行转换成字典

很神奇吧,其实还有一种创建方法,也给大家说下吧

第四种,dict1.fromkeys(seq[,val]),创建并返回一个新字典,以seq中的元素做该字典的键,val做该字典中所有键对应的初始值(默认为None);

演示给大家看下:

从这里可以看出来如果不设置val的话那么默认生成的就是None,大家也动手敲一下,嘻嘻!

接下来既然创建好了,那么就可以进行最经典的增、删、查、改的操作啦,哈哈哈!

为了让大家有个印象我先将字典常用的方法贴出来给大家看下:

dict1.clear()                              #移除dict1中的所有项
dict1.copy()                               #返回dict1的副本
dict1.fromkeys(seq[,val])                  #创建并返回一个新字典,以seq中的元素做该字典的键,val做该字典中所有键对应的初始值(默认为None);
dict1.get(key[,default])                   #如果dict1[key]存在,将其返回;否则返回给定的默认值None  
dict1.keys()                               #返回dict1键的列表
dict1.pop(key[,hello])                     #[]之间可以不要,dict1.pop(key[,default]) 和get方法相似。如果字典中存在key,删除并返回key对应的vuale;如果key不存在,且没有给出default的值,则引发keyerror异常;
dict1.popitem()                            #从dict1中移除任意一项,并将其作为(键,值)对返回
dict1.setdefault(key[,default])            #如果dict1[key]存在则将其返回key的values;否则返回默认值None
dict1.update(other)                        #将other中的每一项加入到dict1中。
dict1.values()                             #返回dict1中值的列表dict1.copy()                               #返回一个字典的浅复制
dict1.items()                              #返回表示dict1项的(键,值)对列表
dict1.iteritems()                          #从dict1.items()返回的(键,值)对中返回一个可迭代的对象
dict1.iterkeys()                           #从dict1的键中返回一个可迭代对象
dict1.itervalues()                         #从dict1的值中返回一个可迭代对象

2、字典增加

  这个相对比较简单,以下说字典的方法时都默认已经创建了一个字典,内容为dict1 = {‘x‘: 1, ‘y‘: 2}

要想增加内容,直接写新的键值加入即可,如右图

3、字典删除

删除的话有几种方法:

1.dict1.pop(key[,default]) 和get方法相似。如果字典中存在key,删除并返回key对应的vuale;如果key不存在,且没有给出default的值,则引发keyerror异常;

通过pop指定key删除,如果key不存在则返回hello默认值

2.dict1.popitem(),这个是随机删除字典的一项,可能你使用的时候会觉得是删除最后一项,但是因为字典本身是无序的,因此不存在说一定是删除某个值,效率很高

3.dict1.clear() ,clear 方法清除字典中所有的项。这是个原地操作,所以无返回值(或者说返回 None)。

4.del dict1或del dict1[key],删除字典的值或者字典,删除字典后,字典将不存在

4、字典修改

字典修改也有几种方法,哎,方法真多,是不是记得很蛋疼啊,哈哈哈,其实不然,用手敲一下,抱着兴趣的心态看看,我相信你会变得很喜欢的。

字典最方便的修改方法就是直接赋值就好了,举个例子

是不是特别简单呢?直接通过key修改即可

这里另外说一个字典更新的方法:dict1.update(other),这个方法是什么呢?是把一个字典加到另一个字典里面去,没有的就添加,有的就修改。

5、字典查找

我们创建了字典往往是为了保存数据的,既然保存了我们想要的数据,那当然就要在适当的时候取出来了,这个是字典比较重要的,方法也较多,其实在我们学的数据库,linux对于查找的命令都是很重要而且较多的,下面来给大家逐个介绍下吧!

1.dict1.get(key[,default]) ,如果dict1[key]存在,将其返回;否则返回给定的默认值None  ,看下面的例子你就知道了

2.in,类似于python2.7里面的has_key,判断一个键是否在一个字典里面,有就True没有就False

3.直接通过key值查询value即可,

4.dict1.keys() ,keys 方法将字典中的键以 dict_keys 形式返回,dict1.values(),values方法将字典中的键以 dict_values 形式返回

.

5.dict1.setdefault(key,default=None) ,和get()类似, 但如果键不存在于字典中,将会添加键并将值设为default

6.dict1.items(),以列表返回可遍历的(键, 值) 元组数组

当然除了上面的还有一个copy的方法,这个也在这里说一下吧,虽然不是什么查询相关的,这个是复制,也叫浅拷贝。

dict1.copy(),什么是浅拷贝看下面的实例便知道了

实例中 dict2 其实是 dict1 的引用(别名),所以输出结果都是一致的。dict3 父对象进行了深拷贝(也就是一级目录深拷贝),不会随dict1 修改而修改,子对象(二级目录)是浅拷贝所以随 dict1 的修改而修改。

时间: 2024-11-09 06:17:46

零基础学习python_字典(25-26课)的相关文章

零基础学习python_字符串(14-15课)

今天回顾下我之前学习python的第一个对象--字符串,这个对象真蛋疼,因为方法是最多的,也是最常见的类型,没有之一... 内容有点多,我就搜了下网上的资料,转载下这个看起来还不错的网址吧:http://www.cnblogs.com/PeterZhang1520389703/p/7647160.html str.capitalize() --> String 返回字符串,其首字母大写,其余部分小写 1>>> str = "TEST" 2>>>

零基础学习python_列表和元组(10-13课)

一时兴起今天又回过头来补一下列表和元组,先来说说列表哈,列表其实是python最经常用到的数据类型了,不仅经常用还很强大呢,这个跟C语言里面的数组是类似的,列表当然也可以增删改查,不过我可没打算用之前字典的方式给大家讲解,我给大家讲解下列表的常用方法就好了. 1.首先我先讲下怎么创建一个列表,你看下方list1是创建了一个空列表,list2是创建了一个有值列表. 2.list1.append(),这个方法是在列表末尾追加,看下面例子: 记得append()方法是列表末尾追加 这种末尾追加虽然可以

蓝鸥零基础学习HTML5—html+css基础

蓝鸥零基础学习HTML5-html+css基础 一.课程目标 1.了解前端开发职位:2.掌握常用标签以及语义及用法:3.掌握常用css的特性,掌握基础布局技巧:4.掌握整站规划概念. 二.适用人群 零基础积极学习html5者 三.课程简介 本课程主要讲解了 html+css的基础知识,包括html模板.标签.css基础样式.布局.表格表单.整站等等,是进行前端开发的基础.Html+css是前端开发的基础,大部分前端开发工程都需要从html+css布局开始,html+css的基础非常重要,是前端开

零基础学习Mahout之一:搭建单机环境

一.Mahout是什么? Mahout是Apache的一个开源项目(http://mahout.apache.org/),提供了机器学习领域的若干经典算法,以便开发人员快速构建机器学习和数据挖掘方面的应用. Mahout是基于Hadoop的.从名称上看也很有意思,Hadoop是一个大象的名字,而Mahout则是象夫.看象人,可见二者联系之紧密.(这让我自然联想到Sun和Eclipse...) 我此时是一个完全没用过Mahout的门外汉,对Hadoop也没有实际使用经验,算是真正的零基础.我的目标

salesforce 零基础学习(五十二)Trigger使用篇(二)

第十七篇的Trigger用法为通过Handler方式实现Trigger的封装,此种好处是一个Handler对应一个sObject,使本该在Trigger中写的代码分到Handler中,代码更加清晰. 十七篇链接:salesforce 零基础学习(十七)Trigger用法 有的时候对于sObject的trigger处理复杂的情况下,比如一个sObject的before update要实现功能1,2.....n功能情况下,Handler中需要在before update写实现功能1--n的代码.然而

salesforce零基础学习(八十二)审批邮件获取最终审批人和审批意见

项目中,审批操作无处不在.配置审批流时,我们有时候会用到queue,related user设置当前步骤的审批人,审批人可以一个或者多个.当审批人有多个时,邮件中获取当前记录的审批人和审批意见就不能随便的取一个审批人了,有以下方式针对不同的场景可以获取到当前记录的最终审批人以及审批意见. 邮件内容使用以下几种方式实现: 1.代码里面实现邮件发送 2.email template(text/html/custom) 3.visualforce emailTemplate 对发送邮件方式不清楚的,可

salesforce零基础学习(八十九)使用 input type=file 以及RemoteAction方式上传附件

在classic环境中,salesforce提供了<apex:inputFile>标签用来实现附件的上传以及内容获取.salesforce 零基础学习(二十四)解析csv格式内容中有类似的使用此标签进行解析附件内容,后台只要声明String类型变量用来存储附件名称,Blob类型变量用来存储附件的内容即可. 但是当我们的项目整体使用第三方的前端框架,例如VUE或者angular等前端框架时,有时使用apex:inputFile反而不是很方便,需要用到html的原生的附件上传的标签<inpu

[原]零基础学习视频解码系列文章

注:本系列文章的开发环境:Ubuntu 14.04+Eclipse4.3.2+CDT+FFmpeg2.3+SDL1.25 [原]零基础学习视频解码之安装ffmpeg [原]零基础学习视频解码之FFMpeg中比较重要的函数以及数据结构 [原]零基础学习视频解码之解码图像 [原]SDL开发教程 [原]零基础学习视频解码之解码声音 [原]零基础学习视频解码之视频线程 [原]零基础学习视频解码之同步视频 [原]零基础学习视频解码之同步音频 [原]零基础学习视频解码之seek [原]零基础学习视频解码之后

零基础学习hadoop到上手工作线路指导(中级篇)

此篇是在零基础学习hadoop到上手工作线路指导(初级篇)的基础,一个继续总结. 五一假期:在写点内容,也算是总结.上面我们会了基本的编程,我们需要对hadoop有一个更深的理解: hadoop分为hadoop1.X.hadoop2.X,并且还有hadoop生态系统.这里只能慢慢介绍了.一口也吃不成胖子. hadoop 1.x分为 mapreduce与hdfs其中mapreduce是很多人都需要迈过去的槛,它比较难以理解,我们有时候即使写出了mapreduce程序,但是还是摸不着头脑. 我们不知