字典、列表、元组

 1 字典
 2 Python内置的字典数据类型:全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度
 3 
 4 当将key-value放进dict时,dict会根据key算出value要存放地址,并将value放入该地址
 5 当通过key从dict获取value时,dict会根据key算出value存放的地址,然后访问该地址获取value
 6 这个通过key计算位置的算法称为哈希算法(Hash)
 7 
 8 dict的一个key只能对应一个value,多次对一个key放入value,后面的值会覆盖前面的值
 9 dict内部存放的顺序和key放入的顺序是没有关系的
10 
11 dict和list的比较
12   list:1) 查找和插入的时间随着元素的增加而增加
13        list总是从第一个元素开始查找,知只到找到目标元素为止
14      2) 内存占用大,内存浪费多
15 
16   dict:1)  查找和插入的速度极快,不会随着key的增加而变慢
17        dict先从字典索引查到value具体地址后,再根据具体地址找到value值
18        这样即使dict里的数据很多也不会降低查询速度
19        就像当你知道某个单词在字典的具体哪一页后,即使字典再厚,你总能一下子找到那个单词
20        2)  内存占用小,内存浪费少
21 
22 注意:1) dict是用空间来换取时间的一种方法,
23    2) dict的key必须是不可变对象
24      由于key是dict用来计算value的存储地址的,如果key是经常变化的,则每次计算相同的key会得出不同的存储地址,那dict内部就完全混乱了
25      因此要保证通过key计算得出的value的存储地址的正确性,作为key的对象就不能变
26      在Python中,字符串、整数等都是不可变的,所以可放心地作为key,而list是可变的,就不能作为key
27 
28 使用示例:
29 
30 初始化dict
31 d = {'Michael': 95, 'Bob': 75, 'Tracy': 85}
32 print(d['Michael'])  #输出:Michael
33 print(d['tttt']) #输出:key不存在会报错,如:KeyError: 'tttt'
34 
35 通过key放入dict
36 d['Adam'] = 67
37 print(d['Adam'])  #输出:67
38 
39 判断key是否存在
40 1 通过in判断key是否存在
41     print('Thomas' in d)   #输出:False 
42     
43 2 通过dict提供的get()方法,如果key不存在,可以返回None,或者自定义value
44     print(d.get('Thomas'))  #输出:None,控制台什么也不显示
45     print(d.get('Thomas'),-1)  #输出:-1
46 
47 删除key-value键值对
48 print(d.pop('Bob')) #输出:75, 返回该key对应的value
49 
50 将list放入dict
51 d={[1,2,3]}  #typeError:unhashable type:'list', 原因是list是可变的,不能作为key

 

转载于:https://www.cnblogs.com/SP-0306/p/10882579.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/277701.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Sublime Text怎么快速建立一个html5页面模板

在编辑器中输入一个半角英文的感叹号(!),然后按下TAB键

Mac OS X 10.10更新及体验

前一阵子,更新了Mac OS 10.10 Yosemite,总体用起来感觉还是很不错的,是很值得升级,相对于10.9 Mavericks优化了不少东西。我之前写的使用教程有一些也就不适用了;比如更换Dashboard中的背景,10.10中Dashboa…

快速幂学习笔记

啥是快速幂 快速幂,顾名思义,就是快速算某个数的多少次幂。其时间复杂度为 \(O(\log N)\), 与朴素的\(O(N)\)相比效率有了极大的提高。 原理 来自学长: 我们可以把 \(b\) 分解成二进制数,其中从小到大每一个二进制位 是…

文本处理工具sed

sed:stream Editor流编辑器,默认不编辑原文件,仅对模式空间中的数据做处理;而后,处理结束后,将模式空间打印至屏幕。语法: sed [option] AddressCommand file1 file2... option选项有&#xff1…

Mac OS X必备APP推荐之一

本篇博文要推荐一下装机必备的APP,因为电脑的使用需求因人而异,这里我根据我的见解和长时间的使用经验推荐一些我认为大家基本都用得到的APP,太过专业性质的我就不推荐了,当然我的推荐肯定会有疏漏和偏差的地方,还请熟…

2018-2019-2 20175235 实验四《Android开发基础》实验报告

实验目的 一、Android Studio的安装测试 二、Activity测试 三、UI测试 四、布局测试 五、事件处理测试 一.Android Stuidio的安装测试: 参考《Java和Android开发学习指南(第二版)(EPUBIT,Java for Android 2nd)》第二十四章: 参考http://www.cnblogs.com…

Mac OS X必备APP推荐之二

本篇接着上一篇APP推荐的博文,继续为大家推荐Mac下好用的APP。 一、首先推荐一款DaisyDisk,磁盘分析、清理工具。前面第一篇APP推荐中,我们推荐过APP和系统垃圾清理工具——Cleanmymac,这两个APP侧重有所不同。Cleanmymac主要清理…

【编程大系】Java资源汇总

1.学习资料: 1)Spring Boot 那些事:https://www.w3cschool.cn/springboot/ 对应的 gitHub代码: https://github.com/JeffLi1993/springboot-learning-example 2)Spring Boot基础视频:https://www.w3cschool…

Mac OSX使用VMware Fusion安装windows虚拟机教程

安装虚拟机之前,先要有两步准备工作。第一,安装并激活VMware Fusion,如果大家还没有下载VMware Fusion请参照上一篇博文,APP推荐之二,下载VMware Fusion并激活。第二,下载你想要安装的系统镜像。因为已经装…

利用CAGradientLayer自定义颜色渐变view

说个故事: UI设计对大家说:“我们拒绝炒现饭!"。 然后就加了一波特效。 程序员猝。 #####效果分析: 1.水波动画。 2.背景颜色渐变。 #####实现思路: 1.水波动画,用CGMutablePathRef和三角函数画出波浪线,让后利用…

【笔记】spring定时器时间配置实例

"0/10 * * * * ?" 每10秒触发 "0 0 12 * * ?" 每天中午12点触发 "0 15 10 ? * *" 每天上午10:15触发 "0 15 10 * * ?" 每天上午10:15触发 "0 15 10 * * ? *" 每天上午10:15触发 "0 15 10 * * ? 2005" 2…

java简介和开发环境搭建

因为本人的Java一直以来水平都不怎么样,大一的时候只考了60分。所以在临近毕业的时候,我选择了重修Java,这些天正在慢慢的回顾Java,会到博客里面记录一些Java的知识,不为有多少人来看,只希望自己有所收获。…

第六章 函数和宏定义实验(2)

C程序设计实验报告 实验项目: 1、利用复化梯形公式计算定积分 2、计算Ackerman函数 3、编写计算x的y次幂的递归函数getpower(int x,int y),并在主程序中实现输入输出 4、编写计算学生年龄的递归函数 5、编写递归函数实现Ackman函数 姓名:王锦…

将控件保存为图片

原文:将控件保存为图片将控件保存为图片 周银辉 这里分别提供win form 和 wpf 两种方式 对于.net 2.0 我们可以简单地利用 BitBlt 函数来实现,非常简单,代码如下: publicstaticclassControlToImageConverter { privateconstInt32 S…

Linux基础命令---get获取ftp文件

get 使用lftp登录ftp服务器之后,可以使用get指令从服务器获取文件。 1、语法 get [-E] [-a] [-c] [-O base] rfile [-o lfile] 2、选项列表 选项 说明 -o 指定输出文件的名字,不指定则使用原来的名字 -c 如果失败,持续获取 -E 获取…

Unity3D学习笔记之二资源导入以及工程管理

本次教程,我们来建立自己的一个工程并导入模型,对模型进行处理。特别说明:这系列教程参考自人人素材翻译组出品的翻译教程《Unity游戏引擎的基础入门视频教程》,本博客中采用的模型和方法均来源于此。这是我浏览过好多教程后觉得讲…

关于cocos creator换装功能的实践与思考

2019独角兽企业重金招聘Python工程师标准>>> 最近在做一个基于cocos creator的微信小游戏,其中一个主要的功能是给角色进行换装。先来说下开发环境: cocos creator1.9.3spine 在官方的文档中只有设置皮肤的接口,实际上是存在可以部…

pl/sql查询表数据,报错ORA-03115:不支持的网络数据类型或表示法

今天测试人员遇到一个问题:pl/sql查询表数据,报错ORA-03115:不支持的网络数据类型或表示法 我在plsql上查询这张表是没有问题的,去看了那张表,发现有个字段类型是binary_double, 查资料发现这是oracle10才出…

抖店一件代发实操,干货满满!

我是电商珠珠 没有货源的新手,在店铺刚开始的时候可以搞无货源模式,也就是一件代发,去搬运别人店铺的商品到自己店铺,再去利用信息差去赚取差价。 很多人不知道具体要怎么做,今天我就来给大家讲一讲。 一、入驻 入…

Unity3D学习笔记之三Prefab组件的使用

本次教程,我们来创建一个简单的Prefab组件。教程参考自人人素材翻译组出品的翻译教程《Unity游戏引擎的基础入门视频教程》。说到Prefab,中文翻译为预设体,在Unity官方的书本《Unity4.X从入门到精通》中的解释是:可以理解为是一个…