概念

无序的,可变的,键值对集合

定义

方式1

{key1: value1, key2: value2, ......}

方式2

fromkeys(S, v=None)

  • 静态方法:类和对象都可以调用
  • 类调用:dict.fromkeys("xxx", "yyy"),此处的dict指的是字典类型
  • 对象调用:dic.fromkeys("xxx", "yyy"),此处的dic指的是实例化的字典对象

注意

  • key不能重复,如果重复,后面的会把前面的覆盖
  • key必须是任意不可变类型

不可变的原因:

  • python的字典,采用哈希的方式实现
  • 简单存储过程:
    • 初始化一个表格,用来存放所有的值

      • 表格可以称为哈希表
    • 存储一个键值对的时候,会做如下操作
      • 根据给定的key,通过某些操作,得到一个在哈希表中的索引位置

        • 把key通过“哈希函数”转换成一个整型数字,称为哈希值
        • 将该数字对数组长度进行取余,取余结果当做下标
        • 如果产生了“哈希冲突”
          • 采用开放寻址法,通过探测函数查找下一个空位
      • 根据索引位置,存储给定的“值”
  • 简单查找过程
    • 再次使用哈希函数将key转换为对应的列表的索引,并定位到列表的位置获取响应的value

字典的意义

  • 可以通过key,访问对应的值,使得这种访问更具意义
  • 查询效率得到很大提升

常用操作

增加

dic[key] = value:当key不存在的时候,就是增加操作

删除

  1. del dic[key]:删除一个字典元素
  2. dic.pop(key[, default]):删除指定键值对,返回删除的值,如果key不存在,则直接返回给定的default值,如果也没有给default,则报错
  3. dic.popitem():删除按升序排序后的第一个键值对,并以元组的形式返回该键值对,如果字典为空,则报错
  4. dic.clear():删除字典内所有键值对,返回None,只是内容被清空,字典本身还存在

修改

只能改值,不能改key

修改单个键值对:dic[key] = value

批量修改键值对:oldDic.update(newDic)

查找

获取单个值

  1. dic[key]:如果key不存在,则报错
  2. dic.get(key[, default]):如果不存在则返回default,如果也没有default,返回None,但是原字典不会增加这个键值对
  3. dic.setdefault(key[, default]):如果key不存在,则设置指定的默认值,并返回该值,如果默认值没有指定,则使用None代替

获取所有值

dic.values()

获取所有的键

dic.keys()

获取所有的键值对

dic.items()

py3和py2的区别

python2中,上面几个直接是一个列表,可以通过下标进行获取指定元素

python3中,是Dictionary view objects

在python2中,还提供了viewkeys() viewvalues() viewitems(),作用相当于python3中的view objects

遍历

可以分别遍历键,值,键值对

也可以一起遍历:

for k,v in kvs:
......

in

in用在字典里,判断的是key

以前有一个方法:has_key(),来判断是否存在某个键值,现在已经不用了

Python:字典类型的更多相关文章

  1. [转载]关于python字典类型最疯狂的表达方式

    一个Python字典表达式谜题 让我们探究一下下面这个晦涩的python字典表达式,以找出在python解释器的中未知的内部到底发生了什么. # 一个python谜题:这是一个秘密 # 这个表达式计算 ...

  2. python字典类型

    字典类型简介 字典(dict)是存储key/value数据的容器,也就是所谓的map.hash.关联数组.无论是什么称呼,都是键值对存储的方式. 在python中,dict类型使用大括号包围: D = ...

  3. Python字典类型、

    字典类型: # msg_dic = {#     'apple': 10,#     'tesla': 100000,#     'mac': 3000,#     'lenovo': 30000,# ...

  4. python中字典类型的使用

    Python字典类型 字典是一种键值对的集合,键值对之间无序 字典类型的定义 采用{}或者dict()来创建字典对象,键值对之间使用:进行分隔. {<键1>:<值1>, < ...

  5. Python字典及相关操作(内含例题)

    Python字典类型 今天将会介绍一种在python中十分常见的组合数据类型——字典 通过一些实例来理解字典中的常规操作 什么是字典类型? 列表中查找是通过整数的索引(元素在列表中的序号)来实现查找功 ...

  6. python字典中的元素类型

    python字典默认的是string item={"browser " : 'webdriver.irefox()', 'url' : 'http://xxx.com'} 如果这样 ...

  7. Python变量类型(l整型,长整形,浮点型,复数,列表,元组,字典)学习

    #coding=utf-8 __author__ = 'Administrator' #Python变量类型 #Python数字,python支持四种不同的数据类型 int整型 long长整型 flo ...

  8. python数据类型——字典类型

    字典(dictionary) python中唯一的映射类型,采用键值对(key-value)的形式储存数据,python对key进行哈希函数运算,所以key值必须是可哈希的,可哈希表示key必须是不可 ...

  9. Python编程Day6——元组类型、字典类型、集合

    一.元组类型(tuple) 1.用途:记录多个值,当多个值没有改变的需求此时元组更为合适 2.定义:在()内用逗号分隔开多个任意类型的值(参数为for可以循环的对象) 3.常用操作: 索引(正取向+反 ...

  10. Python的字典类型

    Python的字典类型为dict,用{}来表示,字典存放键值对数据,每个键值对用:号分隔,每个键值对之间用,号分隔,其基本格式如下: d = {key1 : value1, key2 : value2 ...

随机推荐

  1. OpenCV图像载入、显示和输出到文件以及滑块的使用

    图像载入 imread()函数 Mat imread(const string& filename, int flags = 1); 第一个参数为文件名 第二个参数为载入标识 flags &g ...

  2. torchvision的理解和学习 加载常用数据集,对主流模型的调用.md

    torchvision的理解和学习 加载常用数据集,对主流模型的调用 https://blog.csdn.net/tsq292978891/article/details/79403617 加载常用数 ...

  3. 常用统计分析python包开源学习代码 numpy pandas matplotlib

    常用统计分析python包开源学习代码 numpy pandas matplotlib 待办 https://github.com/zmzhouXJTU/Python-Data-Analysis

  4. rancher说明为什么需要按照指定版本安装以及rancher和节点linux环境配置-docker指定版本安装

    rancher说明为什么需要按照指定版本安装以及rancher和节点linux环境配置-docker指定版本安装 待办 https://blog.csdn.net/CSDN_duomaomao/art ...

  5. NOIP2012 疫情控制 题解(LuoguP1084)

    NOIP2012 疫情控制 题解(LuoguP1084) 不难发现,如果一个点向上移动一定能控制更多的点,所以可以二分时间,判断是否可行. 但根节点不能不能控制,存在以当前时间可以走到根节点的点,可使 ...

  6. Django项目报错: 禁止访问(403),CSRF验证失败,相应中断

    如果想要取消表单的CSRF防护,可以在模板上删除{% csrf_token %}, 并且在相应的视图函数中添加装饰器@csrf_exempt, 代码如下: from django.views.deco ...

  7. C语言合法标识符 题解

    输入一个字符串,判断其是否是C的合法标识符.  Input输入数据包含多个测试实例,数据的第一行是一个整数n,表示测试实例的个数,然后是n行输入数据,每行是一个长度不超过50的字符串. Output对 ...

  8. python 字符串的一些函数

    split()函数 split()      以 空格 为分割符分割字符串,返回列表 split('_')   以'_'为分割符分割字符串,返回列表 strip() 函数  去掉前后的空格 下面是字符 ...

  9. 【转载】C++面试题(1-50)

    转自http://www.jobui.com/mianshiti/it/cpp/5017/ 1.    面向对象的程序设计思想是什么? 答:把数据结构和对数据结构进行操作的方法封装形成一个个的对象. ...

  10. Codeforces Global Round 3:B. Born This Way

    Born This Way原文链接:[传送门] 题目大意:潇洒哥想乘坐飞机从A地到达C地,但是没有直达的航班,在A地和B地之间有一个可以中转的航班B,潇洒哥想早点到达C地(有航班就坐),但是很不幸他得 ...