(python)数据结构---字典
一、描述
- 由键值key-value组成的数据的集合
- 可变、无序的,key不可以重复
- 字典的键key要可hash(列表、字典、集合不可哈希),不可变的数据结构是可哈希的(字符串、元组、对象、bytes)
- 字典的值value可以是任意的数据类型
二、字典的相关操作
1、访问字典的值value
- 字典可以通过key去访问对应的值
- key不存在抛出KeyError异常
d = {"name": "wj", "age": 22}
print(d["name"])
运行结果如下:
wj
2、dict.get(key[, default])
- 返回key对应的值value
- key不存在返回缺省值default,如果没有设置缺省值就返回None
d = {"name": "wj", "age": 22}
print(d.get("name"))
运行结果如下:
wj
3、dict.setdefault(key[, default])
- 返回key对应的值value
- key不存在就创建这对kv对,value是default值,如果没有设置default值,缺省为None
d = {"name": "wj", "age": 22}
print(d.setdefault("gender", "F"))
print(d)
运行结果如下:
F
{'name': 'wj', 'age': 22, 'gender': 'F'}
4、通过key去增加或者修改值
- 如果key存在就修改值,如果key不存在就增加该键值对
d = {"name": "wj", "age": 22}
d["name"] = "yzw"
print(d)
d["gender"] = "F"
print(d)
运行结果如下:
{'name': 'yzw', 'age': 22}
{'name': 'yzw', 'gender': 'F', 'age': 22}
5、dict.update([other])
- 使用另外一个字典的kv对更新本字典
- 如果key存在,就更新,不存在,就增加
d = {"name": "wj", "age": 22}
d.update(name="yaw")
d.update((("gender", "F"), ))
d.update({"birthday": "8-7"})
print(d)
运行结果如下:
{'gender': 'F', 'name': 'yaw', 'birthday': '8-7', 'age': 22}
6、dict.pop(key[, default])
- key存在,移除它,并返回它的值value
- 可以不存在,返回默认值defalut,没有设置defalut,抛出异常KeyError
d = {"name": "wj", "age": 22}
d.pop("name")
print(d)
运行结果如下:
{'age': 22}
7、dict.popitem()
- 移除并返回一个任意的键值对
- 如果字典为空,抛异常KeyError
d = {"name": "wj", "age": 22}
d.popitem()
print(d)
运行结果如下:
{'name': 'wj'}
8、dict.clear()
- 清空字典
9、字典的删除
- 通过del语句直接删除字典或者删除指定的key
d = {"name": "wj", "age": 22}
del d["name"]
print(d)
del d
# print(d) NameError: name 'd' is not defined
运行结果如下:
{'age': 22}
10、字典遍历
- 遍历key
d = {"name": "wj", "age": 22}
for k in d:
print(k)
d = {"name": "wj", "age": 22}
for k in d.keys():
print(k)
- 遍历value
d = {"name": "wj", "age": 22}
for k in d:
print(d[k])
d = {"name": "wj", "age": 22}
for k in d:
print(d.get(k))
d = {"name": "wj", "age": 22}
for k in d.values():
print(k)
- 遍历item,键值对
d = {"name": "wj", "age": 22}
for k, v in d.items():
print(k, v)
11、字典遍历和移除
- 注意,字典在遍历的时候是不能够移除其元素的,否则抛异常RuntimeError
- 如果想要在遍历的时候移除元素,可以在遍历的时候将key加入到一个列表中,然后遍历这个列表,来移除key
d = {"name": "wj", "age": 22}
keys = []
for k, v in d.items():
keys.append(k)
for k in keys:
d.pop(k)
print(d)
运行结果如下:
{}
12、工厂函数defaultdict
- 当key不存在的时候,会调用这个工厂函数来生成key对应的值value
from collections import defaultdict
import random d = defaultdict(list)
for k in "abcde":
for i in range(random.randint(1, 5)):
d[k].append(i) print(d) 运行结果如下:
defaultdict(<class 'list'>, {'d': [0, 1, 2, 3], 'a': [0], 'c': [0, 1, 2, 3, 4], 'b': [0, 1, 2, 3, 4], 'e': [0, 1, 2, 3, 4]})
13、有序字典OrderedDict
- 有序字典会记录元素插入的顺序,打印的时候也是按照这个顺序打印的
- 比如:有的时候需要取出ID,希望是按照输入时的顺序取出,因为输入时的顺序是有序的,这种情况可以使用有序字典
d = {'banana': 3, 'apple': 4, 'pear': 1, 'orange': 2}
print(d)
from collections import OrderedDict
od = OrderedDict()
for k, v in d.items():
od[k] = d[k]
print(od)
运行结果如下:
{'pear': 1, 'orange': 2, 'banana': 3, 'apple': 4}
OrderedDict([('pear', 1), ('orange', 2), ('banana', 3), ('apple', 4)])
(python)数据结构---字典的更多相关文章
- python 数据结构-字典
原文地址:http://docs.pythontab.com/python/python3.4/datastructures.html#tut-tuples 理解字典的最佳方式是把它看做无序的键: 值 ...
- Python数据结构-字典
tel={,} tel[ print(tel) print(tel['tom']) del tel['tom'] print(tel) print(tel.keys()) 运行结果: {, , } { ...
- Python数据结构:列表、元组和字典
在Python中有三种内建的数据结构——列表list.元组tuple和字典dict 列表中的项目包括在方括号中,项目之间用逗号分割 元组和列表十分类似,只不过元组和字符串一样是不可变的 即你不能修改元 ...
- python数据结构与算法
最近忙着准备各种笔试的东西,主要看什么数据结构啊,算法啦,balahbalah啊,以前一直就没看过这些,就挑了本简单的<啊哈算法>入门,不过里面的数据结构和算法都是用C语言写的,而自己对p ...
- python数据结构之图的实现
python数据结构之图的实现,官方有一篇文章介绍,http://www.python.org/doc/essays/graphs.html 下面简要的介绍下: 比如有这么一张图: A -> B ...
- Python数据结构与算法--List和Dictionaries
Lists 当实现 list 的数据结构的时候Python 的设计者有很多的选择. 每一个选择都有可能影响着 list 操作执行的快慢. 当然他们也试图优化一些不常见的操作. 但是当权衡的时候,它们还 ...
- Python数据结构与算法--算法分析
在计算机科学中,算法分析(Analysis of algorithm)是分析执行一个给定算法需要消耗的计算资源数量(例如计算时间,存储器使用等)的过程.算法的效率或复杂度在理论上表示为一个函数.其定义 ...
- Python数据结构之注意事项
1.列表 列表是Python中使用最频繁的数据结构,列表提供很多函数操作,比如下标存取,分片,index,append,remove等等. 例如: list=[1,2,'hello','python ...
- Python数据结构之四——set(集合)
Python版本:3.6.2 操作系统:Windows 作者:SmallWZQ 经过几天的回顾和学习,我终于把Python 3.x中的基础知识介绍好啦.下面将要继续什么呢?让我想想先~~~嗯,还是 ...
- Python学习【第2篇】:Python数据结构
Python数据结构 1.数字类型 2.字符串 3.列表 4.元组 5.字典 6.集合
随机推荐
- 从面试连跪到收割offer,回顾我的春招面试历程(研发岗位)
本文首发于自微信公众号[程序员江湖] 作者How 2 Play Life,985 软件硕士,阿里 Java 研发工程师,在技术校园招聘.自学编程.计算机考研等方面有丰富经验和独到见解,目前致力于分享程 ...
- Spring Boot 1.5升级2.1 主要问题汇总
我们目前工作的系统是基于Spring Boot 1.5.19.RELEASE.Spring Cloud Edgware.SR3开发的,因为一个新项目开发过程的体验,所以在考虑升级到Spring Boo ...
- .Net程序员学用Oracle系列(19):导出、导入(备份、还原)
1.传统的导出/导入工具 1.1.EXP 命令详解 1.2.IMP 命令详解 1.3.EXP/IMP 使用技巧 2.新的导出/导入工具 2.1.EXPDP/IMPDP 参数说明 2.2.EXPDP/I ...
- 呕心沥血之作,最多坑mysql5.7安装教程
前言: 业务需要,需要数据库接binlog发数据变更消息,但是项目用到的数据库是mysql5.6,不支持,于是就有了接下来的一切一切,新的测试服务器上安装mysql5.7 安装步骤: 1.官网下载my ...
- dubbo自定义异常传递信息丢失问题解决
访问我的博客 目前计划对已有的单体项目进行组织架构拆分,调研了分布式系统中常用中间件 Dubbo 和 Spring Cloud,选择了 Dubbo,可以对当前现有项目进行平滑升级改造.但是一开始就遇到 ...
- 支付宝客户端架构解析:Android 容器化框架初探
摘要: 本文将介绍支付宝 Android 容器化框架设计的基本思路. 1. 前言 由本章节开始,我们将从支付宝客户端的架构设计方案入手,细分拆解客户端在“容器化框架设计”.“网络优化”.“性能启动优化 ...
- curl模拟post json或post xml文件
转自: https://www.cnblogs.com/xiaochina/p/9750851.html 问题描述: Linux用命令模拟接口,对接口判断!post文件xml/json 问题解决: c ...
- Socket网络编程基本介绍
一,socket的起源 socket一词的起源 在组网领域的首次使用是在1970年2月12日发布的文献IETF RFC33中发现的, 撰写者为Stephen Carr.Steve Crocker和Vi ...
- Spring基础系列-容器启动流程(2)
原创作品,可以转载,但是请标注出处地址:https://www.cnblogs.com/V1haoge/p/9503210.html 一.概述 这里是Springboot项目启动大概流程,区别于SSM ...
- μC/OS-II 创建一个任务的流程
1. 声明任务的优先级.任务堆栈的大小及任务函数 #define LED_TASK_PRIO 6 #define LED_STK_SIZE 64 void led_task(void *pdata); ...