EmmmuaCode EmmmuaCode
首页​
导航🚀​
  • 数据结构
  • 计算机网络
  • Java基础

    • JavaSE
    • JVM虚拟机
    • JUC并发编程
  • JavaWeb

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

    • ElasticSearch
  • 消息队列

    • RabbitMQ
  • 服务器

    • Nginx🌐
  • 服务框架

    • Dubbo
  • Python基础
  • 数据分析
  • Hadoop
  • SQL 数据库

    • MySQL
  • NoSQL 数据库

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

    • MyBatis
    • MyBatis-Plus
    • ShardingSphere
  • 部署

    • Linux
    • Docker
  • 管理

    • Maven
    • Git
  • 友情链接
  • 优秀博客文章
  • 索引

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

    • 关于
Github (opens new window)

wufan

海内存知己,天涯若比邻。
首页​
导航🚀​
  • 数据结构
  • 计算机网络
  • Java基础

    • JavaSE
    • JVM虚拟机
    • JUC并发编程
  • JavaWeb

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

    • ElasticSearch
  • 消息队列

    • RabbitMQ
  • 服务器

    • Nginx🌐
  • 服务框架

    • Dubbo
  • Python基础
  • 数据分析
  • Hadoop
  • SQL 数据库

    • MySQL
  • NoSQL 数据库

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

    • MyBatis
    • MyBatis-Plus
    • ShardingSphere
  • 部署

    • Linux
    • Docker
  • 管理

    • Maven
    • Git
  • 友情链接
  • 优秀博客文章
  • 索引

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

    • 关于
Github (opens new window)
  • Python 基础

    • Python 基础篇(一)
    • Python 基础篇(二)
    • Python 基础篇(三)
    • Python 基础篇(四)
    • Python 基础篇 (五)
    • Python 列表
    • Python 字典
      • 什么是字典
      • 字典的创建
      • 字典的常用操作
        • 字典中元素的获取
        • []如果字典中不存在指定的key,抛出keyError异常
        • 字典的增删改
        • 字典的视图操作
        • 字典元素的遍历
      • 字典的特点
      • 字典生成式
    • Python 元组和集合
    • Python 字符串
    • Python 函数与变量作用域
    • Python 异常处理
    • Python 面向对象
    • Python 模块与包
    • Python 文件
    • 学生信息管理系统
  • 数据分析

    • 数据分析介绍
    • 环境搭建
    • Numpy库
    • Pandas 库
  • 大数据

    • 大数据基本导论
  • Hadoop

    • hadoop集群搭建
    • HDFS详解
    • HDFS API
    • MapReduce
    • MapReduce原理及API
    • YARN
  • zookeeper

    • zookeeper详细文档
  • Hive

    • Hive基础
    • Hive SQL语法大全
    • Hive性能调优
  • 工具

    • Flume 详细文档
    • Sqoop详细文档
    • Azkaban详细文档
  • studynotes
  • bigdata
  • Python
wufan
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
#Python
上次更新: 2024/04/21, 09:42:22
Python 列表
Python 元组和集合

← Python 列表 Python 元组和集合→

最近更新
01
微信支付功能的实现与流程
11-21
02
购物车与结算区域的深入优化与功能完善
11-21
03
购物车与结算区域的功能实现与优化
11-21
更多文章>
Theme by Vdoing | Copyright © 2023-2024 EmmmuaCode | 黔ICP备2022009864号-2
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式