Python学习(四)数据结构 —— dict

词典类型 dict

  字典由键(key)和对应值(value)成对组成。字典也被称作关联数组或哈希表。

  dict 赋值

  dict 整体放在花括号{}中,每个键与值用冒号隔开(:),每对用逗号分割; d = {‘one‘:1, ‘two‘:2, ‘three‘:3}

  键必须独一无二,但值则不必;值可取任何数据类型,如字符串,数或元组;若创建时同一个键被赋值两次,后一个值会被记住;

  键必须不可变,所以可以用数,字符串或元组充当,用列表就不行

  用 dict() 强制转换,可接受以下形式,参见下例

1 a = dict(one=1, two=2, three=3)
2 b = {‘one‘: 1, ‘two‘: 2, ‘three‘: 3}
3 c = dict(zip([‘one‘, ‘two‘, ‘three‘], [1, 2, 3]))
4 d = dict([(‘two‘, 2), (‘one‘, 1), (‘three‘, 3)])
5 e = dict({‘three‘: 3, ‘one‘: 1, ‘two‘: 2})
6 print(a == b == c == d == e)

  dict 操作

    词典类型适用于对应键的取值,十分实用;对于dict的访问、修改、增加、删除等操作需要熟练掌握

    以下列出了常用的用法,详细请参考:

    访问值、修改值

      dict_name[‘key_name‘] 可直接访问值,可直接更改该值

1 d = {‘Name‘: ‘Zara‘, ‘Age‘: 7, ‘Class‘: ‘First‘};
2 print(d[‘Name‘],d[‘Age‘],d[‘Class‘])            # 访问键值访问 dict_name[‘key_name‘]
3 print("%s‘s age is %d, class is: %s." %(d[‘Name‘], d[‘Age‘],d[‘Class‘]))    # 字符串输出
4 # print(d[‘name‘])                 # 无该键值,会报错,注意大小写
5 d[‘Age‘] = 8
6 print(d[‘Age‘])                    # 可直接修改键的数值,数值类型不限

    键的增加、删除

      判断key是否存在于dict中,使用 key_name in/not in dict_name;

      增加键值即对新的键赋值 dict_name[‘new key_name‘] = value ;删除键值使用 del dict_name[‘key_name‘];

      清空词典使用 dict_name.clear()

 1 d = {‘Name‘: ‘Zara‘, ‘Age‘: 7, ‘Class‘: ‘First‘};
 2 print(d[‘Name‘],d[‘Age‘],d[‘Class‘])            # 访问键值访问 dict[‘key_name‘]
 3 print("%s‘s age is %d, class is: %s." %(d[‘Name‘], d[‘Age‘],d[‘Class‘]))    # 字符串输出
 4 # print(d[‘name‘])                # 无该键值,会报错,注意大小写
 5 d[‘Age‘] = 8
 6 print(d[‘Age‘])                   # 可直接修改键的数值,数值类型不限
 7 print(‘Name‘ in d)                # 判断键是否存在
 8 print(‘xxx‘ not in d)             # 判断键是否不存在
 9 d[‘Sex‘] = "Female"               # 增加键值直接赋值即可
10 print(d)
11 del d[‘Class‘]                    # 删除键值
12 print(d)
13 # del d[‘Class‘]                  # 若无键值,会报错
14 d.clear()                         # 清空dict
15 print(d)

    dict view objects

      len(dict_name) 返回词典键值组合数,可单独取出所有键 dict_name.keys() , 单独取出所有的值 dict_name.values()

1 d = {‘Name‘: ‘Zara‘, ‘Age‘: 7, ‘Class‘: ‘First‘};
2 print(len(d))                    # 键值的组合数量
3 print(d.keys(),type(d.keys()))   # 为dict_keys 类型,可list()转换为list 或 set()转换为set
4 print(d.values())                # 为dict_values 类型
5 print(d.items())                 # 为dict_items 类型
时间: 2024-10-13 10:20:36

Python学习(四)数据结构 —— dict的相关文章

Python学习笔记——数据结构和算法(一)

1.解压序列赋值给多个变量 任何的序列(或者是可迭代对象)可以通过一个简单的赋值语句解压并赋值给多个变量. 唯一的前提就是变量的数量必须跟序列元素的数量是一样的. >>> data = [ 'ACME', 50, 91.1, (2012, 12, 21) ]>>> name, shares, price, date = data >>> name, shares, price, (year, mon, day) = data >>>

Python学习笔记之dict、set

dict Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度. 举个例子,假设要根据同学的名字查找对应的成绩,如果用list实现,需要两个list: names = ['Michael', 'Bob', 'Tracy'] scores = [95, 75, 85] 给定一个名字,要查找对应的成绩,就先要在names中找到对应的位置,再从scores取出对应的成绩,list越长,耗时越长. 如

【 python 学习笔记 -- 数据结构与算法 】哈希表 Implementation of a Hash Table

Python内建的字典就是用 hash table实现的.这里我们只是通过实现自己的hash table来加深对hash table 和hash functions的理解. [ 概念1: Mapping (映射)] 字典通过键(Key)来索引.一个key对应一个存储的value.任意不可变的数据类型均可作为key. [ 概念2:Hash Table (哈希表)] Hash Table根据key直接访问在内存存储位置的数据结构,因而加快了查找速度 (O(1)). 下图是一个size为11的空的Ha

python学习四十一天(线程)

今日主要内容: 线程的概念和简单应用 线程概念的引入背景 进程 之前我们已经了解了操作系统中进程的概念,程序并不能单独运行,只有将程序装载到内存中,系统为它分配资源才能运行,而这种执行的程序就称之为进程.程序和进程的区别就在于:程序是指令的集合,它是进程运行的静态描述文本:进程是程序的一次执行活动,属于动态概念.在多道编程中,我们允许多个程序同时加载到内存中,在操作系统的调度下,可以实现并发地执行.这是这样的设计,大大提高了CPU的利用率.进程的出现让每个用户感觉到自己独享CPU,因此,进程就是

python学习四十天(进程池)

今日主要内容: 1.队列 2.管道 3.数据共享 4.进程池 5.回调函数 一.队列 队列: 创建共享的进程队列,Queue是多进程安全的队列,可以使用Queue实现多进程之间的数据传递. Queue([maxsize]) 创建共享的进程队列. 参数 :maxsize是队列中允许的最大项数.如果省略此参数,则无大小限制. 底层队列使用管道和锁定实现 Queue([maxsize]) 创建共享的进程队列.maxsize是队列中允许的最大项数.如果省略此参数,则无大小限制.底层队列使用管道和锁定实现

Python学习—基础数据结构之列表

基本数据结构之列表 列表list是一种有序的集合,可以随时添加和删除其中的元素.与c.java中的数组有相似之处,但是c.java中的数组必须存放同一类型的元素,而在python的列表中,存放的元素可以是不同的类型.序列都可以进行的操作包括索引,切片,加,乘,检查成员. 1.列表的表示 创建一个列表,只要把逗号分隔的不同的数据项使用方括号括起来即可. list1 = ['str','中文',123,'Python'] list2 = [2,3,5,78,999] list3 = [['str1'

python学习一使用dict和set

使用dict Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度. 数据放入dict的方法,除了初始化时指定外,还可以通过key放入: >>> d['Adam'] = 67 >>> d['Adam'] 67由于一个key只能对应一个value,所以,多次对一个key放入value,后面的值会把前面的值冲掉,如果key不存在,dict就会报错. 要避免key不存在的错

Python学习笔记 set&&dict

dict 是个好东西啊,这个东东是类似于c++里面的map.其形式为 dict={key:value,key:value....} 这个东西好玩的地方主要在于 1.他的key值查找采用的是哈希算法,速度比较快 2.key值得类型可以不同,但是其key值为不可变对象,例如字符串,即便key值为数字那也是数字常量 3.value值类型也可以不同. 4.可以按key值直接进行添加,如d[1]=123(假设1之前并不是其key值,如果是其key值那么,则是修改value) 5.可以按key值直接进行查找

python学习四天--for 循环

Python for循环可以遍历任何序列的项目,如一个列表或者一个字符串. 语法: for循环的语法格式如下: for iterating_var in sequence: statements(s) #!/usr/bin/env python # -*- coding:utf-8 -*- for i in range(1,100): print (i) good 内存为字典,提前预习了一下字典的写法,这里字典跟REDIS 的键值很像. #!/usr/bin/env python #-*- co

【 python 学习笔记 -- 数据结构与算法 】冒泡排序 Bubble sort

推荐一个可视化的网站 [ Visual Algo ]: URL= 'https://visualgo.net/en/sorting' 这个网站给出了各种排序算法的原理和过程,通过动态形式直观得展现出来.另外还给出了相关的pseudo-code,以及具体执行到code的哪一步. [冒泡排序] 需要重复地走访需要排序的数列.走访过程中比较相邻两个items的大小,如果顺序不对,则交换两个items. 因此,每完成一次走访(pass),需要排序的部分的最大值就会移动到合适的位置. 这个过程看起来就像每