xustudyxu's Blog
首页​
导航🚀​
  • 数据结构
  • 计算机网络
  • Java基础

    • JavaSE
  • JavaWeb

    • HTML
    • CSS
    • JavaScript
    • Vue
    • Servlet
    • MVC
    • filter|listener
  • Spring5
  • SpringMVC
  • SpringBoot2
  • SpringCloud
  • SpringSecurity
  • 搜索引擎

    • ElasticSearch
  • 消息队列

    • RabbitMQ
  • 服务器

    • Nginx🌐
  • 服务框架

    • Dubbo
  • Python

    • Python基础
    • 数据分析
  • 环境搭建

    • Hadoop集群
    • KVM虚拟化技术
  • SQL 数据库

    • MySQL
  • NoSQL 数据库

    • NoSQL数据库概论
    • Redis
    • MongoDB
    • HBase
  • 框架

    • MyBatis
    • MyBatis-Plus
  • 部署

    • Linux
    • Docker
  • 管理

    • Maven
    • Git
  • 十大排序算法
  • 力扣算法题
  • 初级开发篇
  • 中高进阶篇
  • 友情链接
  • 优秀博客文章
  • 索引

    • 分类
    • 标签
    • 归档
  • 其他

    • 关于
查看源码 (opens new window)

xustudyxu

一起学习编程!
首页​
导航🚀​
  • 数据结构
  • 计算机网络
  • Java基础

    • JavaSE
  • JavaWeb

    • HTML
    • CSS
    • JavaScript
    • Vue
    • Servlet
    • MVC
    • filter|listener
  • Spring5
  • SpringMVC
  • SpringBoot2
  • SpringCloud
  • SpringSecurity
  • 搜索引擎

    • ElasticSearch
  • 消息队列

    • RabbitMQ
  • 服务器

    • Nginx🌐
  • 服务框架

    • Dubbo
  • Python

    • Python基础
    • 数据分析
  • 环境搭建

    • Hadoop集群
    • KVM虚拟化技术
  • SQL 数据库

    • MySQL
  • NoSQL 数据库

    • NoSQL数据库概论
    • Redis
    • MongoDB
    • HBase
  • 框架

    • MyBatis
    • MyBatis-Plus
  • 部署

    • Linux
    • Docker
  • 管理

    • Maven
    • Git
  • 十大排序算法
  • 力扣算法题
  • 初级开发篇
  • 中高进阶篇
  • 友情链接
  • 优秀博客文章
  • 索引

    • 分类
    • 标签
    • 归档
  • 其他

    • 关于
查看源码 (opens new window)
  • Python 基础

    • Python 基础篇(一)
    • Python 基础篇(二)
    • Python 基础篇(三)
    • Python 基础篇(四)
    • Python 基础篇 (五)
    • Python 列表
    • Python 字典
    • Python 元组和集合
    • Python 字符串
    • Python 函数与变量作用域
    • Python 异常处理
    • Python 面向对象
    • Python 模块与包
    • Python 文件
    • 学生信息管理系统
  • 数据分析

    • 数据分析介绍
    • 环境搭建
    • Numpy库
    • Pandas 库
  • Hadoop搭建集群

    • 搭建Hadoop集群
    • 搭建Hadoop集群(二)
  • CentOS7 KVM虚拟化技术

    • CentOS7 KVM虚拟化技术
  • studynotes
  • bigdata
  • Python
xu
2021-12-20
目录

Python 字典

# Python 字典

# 什么是字典

  • 字典
  • Python内置的数据结构之一,与列表一样是一个可变序列
  • 以键值对的方式存储数据,字典是一个无序的序列

01

  • 字典示意图

01

  • 字典的实现原理
    • 字典的实现原理与查字典类似,查字典是先根据部首或拼音查找汉字对应的页码。Python中的字典是根据key查找value所在的位置

# 字典的创建

  • 最常用的方式:使用花括号
score={ '张三':100,'李四':98,'王五':45}
1
  • 使用内置函数dict()
dict( name='jack',age=20)
1
"""
@Author :frx
@Time   :2021/10/18 22:25
@Version    :1.0
"""
'''字典的创建方式'''
'''使用{}创建字典'''
scores={'张三':100,'李四':98,'王五':45}
print(scores)
print(type(scores))
'''第二种创建dict()'''
student=dict(name='jack',age=20)
print(student)
'''空字典'''
d={}
print(d)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

# 字典的常用操作

# 字典中元素的获取

01

# []如果字典中不存在指定的key,抛出keyError异常

  • get()方法取值,如果字典中不存在指定的key,并不会抛出keyError而是返回None,可以通过参数设置默认的value,以便指定的key不存在时返回
"""
@Author :frx
@Time   :2021/10/19 19:28
@Version    :1.0
"""
'''获取字典中的值'''
scores={'张三':100,'李四':98,'王五':45}
'''第一种方式,使用[]'''
print(scores['张三']) #100
# print(scores['陈六']) #KeyError: '陈六'
'''第二种方式 使用get()方法'''
print(scores.get('张三')) #100
print(scores.get('陈六')) #None
print(scores.get('麻七',99))  #99是在查找'麻七'不存在时,提供的对应值
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16

# 字典的增删改

  • key的判断

01

  • 字典元素的删除
del scores['张三']
1
  • 字典元素的新增
scores['Jack']=90
1
"""
@Author :frx
@Time   :2021/10/19 19:40
@Version    :1.0
"""
'''键的判断'''
scores={'张三':100,'李四':98,'王五':45}
print('张三' in scores) #True
print('张三' not in scores) #False
del scores['张三'] #删除指定的键值对
# scores.clear()  #清空字典的元素
print(scores)
scores['陈六']=98 # 新增元素
print(scores)
scores['陈六']=100  #修改元素
print(scores)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19

# 字典的视图操作

  • 获取字典视图的三个方法

01

"""
@Author :frx
@Time   :2021/10/19 20:17
@Version    :1.0
"""
scores={'张三':100,'李四':98,'王五':45}
#获取所有的键
keys=scores.keys()
print(keys)  #dict_keys(['张三', '李四', '王五'])
print(type(keys)) #<class 'dict_keys'>
print(list(keys)) #将所有键key 组成的视图转成类表
#获取所有的values
values=scores.values()
print(values)        #dict_values([100, 98, 45])
print(type(values))  #<class 'dict_values'>
print(list(values))
#获取所有的键值对
items=scores.items()
print(items)
print(list(items)) #元组()  转换之后的元素是由元组组成的
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23

# 字典元素的遍历

for item in scores:
    print(item)
1
2
"""
@Author :frx
@Time   :2021/10/19 22:08
@Version    :1.0
"""
#字典元素的遍历
scores={'张三':100,'李四':98,'王五':45}
#字典元素的遍历
for item in scores:
    print(item,scores[item],scores.get(item))
1
2
3
4
5
6
7
8
9
10
11
12

# 字典的特点

  • 字典的特点
    • 字典中的所有元素都是一个key-value对,key不允许重复,value可以重复
    • 字典中的元素都是无序的
    • 字典中的key必须是不可变对象
    • 字典也可以根据需要动态地伸缩
    • 字典会浪费较大的内存,是一种使用空间换时间的数据结构
"""
@Author :frx
@Time   :2021/10/19 22:15
@Version    :1.0
"""
d={'name':'张三','name':'李四'} #key不晕重复 会出现值覆盖
print(d)  #{'name': '李四'}
d={'name':'张三','nikename':'张三'}  #value可以重复
print(d)  #{'name': '张三', 'nikename': '张三'}
lst=[10,20,30]
lst.insert(1,100)
print(lst) #10,100,20,30
# d={lst:100} #TypeError: unhashable type: 'list' key必须是不可变对象
# print(d)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19

# 字典生成式

01

  • 内置函数zip()
    • 用于将可迭代的对象作为参数,将对象中对应的元素打包成一个元祖,然后返回由这些返回由这些元组组成的列表

01

"""
@Author :frx
@Time   :2021/10/19 22:28
@Version    :1.0
"""
items=['Fruits','Books','Others']
price=[96,78,85,100,120]
d={item.upper():price for item,price in zip(items,price)} #以元素少 的列 进行生成
print(d)   #{'FRUITS': 96, 'BOOKS': 78, 'OTHERS': 85}
1
2
3
4
5
6
7
8
9
10
11
12
帮助我改善此页面 (opens new window)
#Python
上次更新: 2024年3月20日
Python 列表
Python 元组和集合

← Python 列表 Python 元组和集合→

最近更新
01
结构型模式
03-21
02
创建者模式
01-20
03
设计模式入门
12-30
更多文章>
Theme by Vdoing | Copyright © 2021-2024 xustudyxu |豫ICP备2022008983号

豫公网安备 41018302000331号

  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式