洗礼灵魂,修炼python(8)--高效的字典
python几大核心之——字典(dict)
1.什么是字典
学生时代都用过字典吧?用这个字的读音,偏旁就能用字典查到其相关信息,词性,意思,组词,造句,还有在什么场合下用这个字等等的。
在python中的这个字典,其实功能是一样的,当然,肯定不是用来查字的,是用来查我们需要的数据的,而且字典要查可以通过网络查字的,而且不止查字,可以查很多东西。
字典的特征号是花括号{}
2.字典的作用:
用来关联数组,或者叫归类数据
3.创建字典的多种方式:
a:直接赋值创建
此处可以看出字典和前面列表,元组,集合都不同的,[‘x]’是key,中文名叫键,用[:]连接,[1]是value,中文名叫值,这三者合在一起作为字典的一个元素。一般称呼字典内一个元素为键值对
b:通过关键字dict和关键字参数创建
c:通过二元组列表创建
d:dict和zip结合创建
zip函数,可以将两个对象结合在一起:
注意python2和python3中zip函数的区别,上面两张图已经给出
e:通过dict.fromkeys()创建
注意fromkeys()方法的用法,自行体会
3.字典的方法
python2:
python3:
因为前后两者差别确实挺大的,结合实际,我就折中抽取都常用的几个:
clear,copy,fromkeys,get,items,keys,pop,popitem,update,setdefault,values
clear:清楚所有,和前一章集合方法一样,不再解析
copy:拷贝,和前一章集合方法一样,也不再解析
fromkeys:生成一个字典对象,上面创建字典时已经讲解
get:根据给的键返回值
注意:get方法,第一个参数是字典的键,第二个参数可有可无。如果访问的字典的键不存在,默认不返回任何东西,如果加入了第二个参数,键不存在则返回给定的第二个参数,但是必须符合python的语法规则
items:以列表的形式返回字典的所有键值对
keys:以列表的形式返回字典的所有键,和items原理相同不再展示
values:以列表的形式返回字典的所有值,和items原理相同不再展示
pop:给定键,删除对应的键值对并返回
popitem:按照字典优先级的排序(或者叫随机)进行删除并返回
update:和字典雷同,用另一个字典更新该字典
setdefault:添加元素,并可以设置一个默认值
但是如果在设定key时,其key已经存在字典的话,则会不变:
4.字典可以像列表使用索引一样访问+修改,但是字典使用的键,而非索引,字典没有索引
5.字典是可变对象,支持原处修改,也就是ID不变,相信也应该不用演示了
6.字典可以做变量解包:
但是元素个数必须对应,不然报错。
注意:字典的键必须是可哈希的值。
什么是可哈希,这里又得提到一个内置函数——hash()
可哈希你可以理解为可被作为依据查找,什么意思?就是判断此对象或者说此元素是否可哈希,如果不可哈希则会报错,上面的列表就是不可哈希,所以报错。
而字典本身是不可哈希的,字典的键才是可哈希的。
你应该要问,为什么字典的键必须得可哈希呢?
答:开头提到的学生时代所用的字典,你查一个字的时候,是需要得到它的读音或者偏旁,在按照字典表跟着查,就能查到在哪,而这里的键就好比你首先知道的读音或者偏旁,用其来作为依据再加上哈希算法就会很快在字典的键里搜索这个键,然后立马返回这个键对应的值,所以在大数据处理时,一般都是用字典的来存储数据的,这样查找起来很快,它不像列表,元组那样,因为列表和元组是有序的,列表和元组默认的查找方式是从索引值为0开始查,换句话就是从头到尾开始查,当数据很大时,这样处理起来的速度是很慢的,用字典直接秒掉列表。
说个实际的例子,像百度等搜索引擎,其实就是用爬虫程序每天在不断爬网页,并用其算法存储关键字通过机制放在字典里,然后当用户用关键词搜索内容时,百度搜索引擎就会很快有反应,把事先存放在字典里包含这个关键词所有相关的信息立马反馈给用户,这一两句话的过程,真正的实现其实大概就一眨眼的功夫(是不是有种感觉在写小说 /手动滑稽),原理是这样的,其实搜索引擎当然不止像我说的这么简单,还有很多复杂的算法来结合实现,不然不可能达到这么快的速度的。好,不多说了。总之,你知道字典很强大就行了。
洗礼灵魂,修炼python(8)--高效的字典的更多相关文章
- 洗礼灵魂,修炼python(85)-- 知识拾遗篇 —— 深度剖析让人幽怨的编码
编码 这篇博文的主题是,编码问题,老生常谈的问题了对吧?从我这一套的文章来看,前面已经提到好多次编码问题了,的确这个确实很重要,这可是难道了很多能人异士的,当你以为你学懂了,在研究爬虫时你发现你错了, ...
- 洗礼灵魂,修炼python(69)--爬虫篇—番外篇之feedparser模块
feedparser模块 1.简介 feedparser是一个Python的Feed解析库,可以处理RSS ,CDF,Atom .使用它我们可从任何 RSS 或 Atom 订阅源得到标题.链接和文章的 ...
- Python基础知识(五)------字典
Python基础知识(四)------字典 字典 一丶什么是字典 dict关键字 , 以 {} 表示, 以key:value形式保存数据 ,每个逗号分隔 键: 必须是可哈希,(不可变的数据类型 ...
- Python 优雅的操作字典【转】
Python 中的字典是Python中一个键值映射的数据结构,下面介绍一下如何优雅的操作字典. 1.1 创建字典 Python有两种方法可以创建字典,第一种是使用花括号,另一种是使用内建 函数dict ...
- 初学Python(三)——字典
初学Python(三)——字典 初学Python,主要整理一些学习到的知识点,这次是字典. #-*- coding:utf-8 -*- d = {1:"name",2:" ...
- python编程基础知识—字典
字典 在python中,字典是一系列键-值对,每个键都与一个值相关联,可使用键来访问相关联的值.与键相关联的值可以是数字.字符串.列表乃至字典,即可将任何python对象用在字典中的值. 在pytho ...
- python调用数据返回字典dict数据的现象2
python调用数据返回字典dict数据的现象2 思考: 话题1连接:https://www.cnblogs.com/zwgbk/p/10248479.html在打印和添加时候加上内存地址id(),可 ...
- python调用数据返回字典dict数据的现象1
python调用数据返回字典dict数据的现象1 思考: 可以看到这两种情况,区别在于构造函数make()里赋值给字典dict的方式不同.使用相同的调用方式,而结果却完全不同.可以看到第二种情况才是我 ...
- python基本数据类型之字典
python基本数据类型之字典 python中的字典是以键(key)值(value)对的形式储存数据,基本形式如下: d = {'Bart': 95, 'Michael': 34, 'Lisa': 5 ...
随机推荐
- [js高手之路]node js系列课程-创建简易web服务器与文件读写
web服务器至少有以下几个特点: 1.24小时不停止的工作,也就是说这个进程要常驻在内存中 2.24小时在某一端口监听,如: http://localhost:8080, www服务器默认端口80 3 ...
- URI和URL的区别 一起学习呗
一直存在很多技术上的争论,其中最为妙的恐怕就是web地址应该叫什么的问题.通常情况就是这样:有人把地址栏的内容叫"URL",这时候有些人就来劲了:"不!其实那就是URI. ...
- Spring @ResponseBody 返回中文乱码问题
详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt102 今天在使用spring 的时候,发现中文返回的是乱码. 经过研究发现, ...
- RadioButtonList控件如何取得选中的值
1.需求:我现在页面上有放两个单选控件,现在要通过判断不同的单选控件来对页面上的标签进行显示和隐藏操作 2.控件如下 <asp:RadioButtonList ID=" RepeatD ...
- PHP初入,div知识点整理(特效&字体等元素的使用整理)
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>& ...
- UTF-8笔记170330
unicode 为每种语言中的每个字符设定了统一并且唯一的二进制编码,以满足跨语言.跨平台进行文本转换.处理的 UTF-8使用可变长度字节来储存 Unicode字符,例如ASCII字母继续使用1字节储 ...
- 网络传输编程之TCP
网络传输编程之TCP 网络传输编程指基于各种网络协议进行编程,包括TCP编程,UDP编程,P2P编程.本节介绍TCP编程. (1)TCP简介: TCP是TCP/IP体系中最重要的传输层协议 ...
- 201521123107 《Java程序设计》第7周学习总结
第7周作业-集合 1.本周学习总结 2.书面作业 1.ArrayList代码分析 1.1 解释ArrayList的contains源代码 源代码如下: public boolean contains( ...
- win8下安装VC6出现兼容性问题的解决办法
重装系统之后(win8的系统),发现VC6安装出现兼容性问题,花了一些时间解决,有出现的问题都差不多在下面链接的总结中,写的很详细: http://www.docin.com/p-1126120829 ...
- ASCII中关于大小写字母间隔为32的思考
一直没有搞清楚为什么在ASCII中要把大小写字母的间隔设置为32,今天才发现这样设置的精妙之处:方便了程序对大小写字母进行转换.请看: ================= 十进制 32 ...