PYTHON知识点学习-字典

🌈write in front🌈
🧸大家好,我是Aileen🧸.希望你看完之后,能对你有所帮助,不足请指正!共同学习交流.
🆔本文由 Aileen_0v0🧸 原创 CSDN首发🐒 如需转载还请通知⚠️
📝个人主页:Aileen_0v0🧸—CSDN博客
🎁欢迎各位→点赞👍 + 收藏⭐️ + 留言📝​
📣系列专栏:Aileen_0v0🧸的PYTHON学习系列专栏——CSDN博客
🗼我的格言:"没有罗马,那就自己创造罗马~" 

目录

字典的介绍及创建

字典查找key

dictionary&list对比

字典的新增修改删除

理解字典操作的效率

字典的遍历

可哈希的类型


字典的介绍及创建

字典:是存储键值对的数据

键(key)

值(value)

根据 key 能够快速找到 value  ( 映射关系 )

例如: 学号 => 同学        名字 => 人

在 python 的字典中,可以同时包含佷多个键值对.

同时要求这些键,不能重复!

#1.创建字典
a = {}
print(type(a))
b = dict()
print(type(b))
#2.创建字典的同时设置初始值.
a ={"id":1 , "name" : "zhangsan"}

 字典a中,包含两个键值对.

(1)"id":1  key 就是"id",value 就是 1

(2)"name":  "zhangsan"  key 就是"name", value 就是"zhangsan"

一个字典中的  key  的类型 不一定都一样

一个字典中的  value  的类型  也不必都一样~

综上,key 和 value 对类型无约束

a ={"id":1 ,"name" : "zhangsan",}

最后一个键值对的逗号可写可不写,其它的必须加上逗号.

字典查找key

#1. 使用 in 来判定某个 key 是否在字典中存在.
a ={"id":1,"name":"zhangsan"
}print("id" in a)
print("classId" in a)# in 只是判定 key 是否存在, 和 value 无关!
print("zhangsan" in a)# not in 来判定 key 在字典中不存在
print("id" not in a)
print("classId" not in a)# 运行结果:
# True
# False
# False
# False
# True
#2. 使用 [ ] 来根据 key 获取到 value
a ={"id" : 1,"name" : "zhangsan",100 : "list"
}print(a["id"])
print(a["name"])
print(a[100])     #注意这里表示的是key100
print(a["classId"])# # 运行结果:
# 1
# zhangsan
# list
# # KeyError: 'classId'#因为找不到

在 Python 中,可以通过多层索引来查找嵌套字典中最里面的值

举个例子,假设有以下嵌套字典

my_dict = {'name': 'John','age': 30,'contacts': {'email': 'john@example.com','phone': {'mobile': '123-456-7890','home': '098-765-4321'}}
}

要查找最里面的电话号码,可以使用以下代码:

phone_number = my_dict['contacts']['phone']['mobile']
print(phone_number)  # 输出: '123-456-7890'

另外,如果不确定某个键是否存在,可以使用 get 方法来避免出错

phone_number = my_dict.get('contacts', {}).get('phone', {}).get('mobile')
print(phone_number)  # 输出: '123-456-7890'

如果某一层嵌套字典不存在,那么 get 方法就会返回一个空字典 {},这样就可以继续向下查找了。

dictionary&list对比

字典的新增修改删除

#1.在字典中新增元素,使用[ ] 来进行.
a = {"id" : 1,"name" : "zhangsan",
}# 这个操作就是往字典里插入新的键值对.
a["score"] = 90
print(a)#2. 在字典中, 根据 key 修改 value, 也是使用 [ ]来进行的~
a["score"] = 100
print(a)#3. 使用 pop 方法, 根据 key 来删除键值对~
a.pop("name")
print(a)
# 运行结果:
# {'id': 1, 'name': 'zhangsan', 'score': 90}
# {'id': 1, 'name': 'zhangsan', 'score': 100}
# {'id': 1, 'score': 100}

可以通过Python中的 update() 方法替换字典中的键值对。该方法接收一个字典作为参数,将该字典中的键值对替换到原字典中对应的键上。

以下是一个简单的示例代码:

dict1 = {"a": 1, "b": 2, "c": 3}
dict2 = {"b": 4, "d": 5}dict1.update(dict2)print(dict1)

输出结果为:

{'a': 1, 'b': 4, 'c': 3, 'd': 5}

可以看到,字典dict2中的键值对已经被替换到了dict1中对应的键上,同时新增的键值对也被添加到了dict1中。如果键已经存在,则新值将取代旧值

小结:字典的各种操作,都是针对 key 来进行的!!
        从而,新增,删除, 获取value,修改value.....

理解字典操作的效率

遍历指的是:能够把一个可迭代对象,里面包含的元素依次取出,并进行一些操作.整个过程要求不重不漏.

字典被设计出来的初衷,不是为了遍历,而是为了增删查改.

字典是 哈希表,进行增删改查操作,效率度非常高!!

字典遍历效率就要一些.

哈希表 这个结构被设计的非常巧妙,能够以"常数级"时间复杂度来完成增删改查~

"常数级":无论字典中有多少元素~

新增,修改,查找 操作都是固定时间,不会因为元素多了,操作就慢了~

❗❗❗哈希表非常重要,后面会继续深入学习发博文

字典的遍历

#1 直接使用 for 循环来遍历字典
a = {"id": 1,"name":"zhangsan","score":90,
}for key in a:print(key,a[key])# 运行结果:
# id 1
# name zhangsan
# score 90

在C++ 或者 Java 中,哈希表里储存的键值对是无序的!

但在 Python 中还不一样~

Python 中做了特殊处理~~能够保证 遍历出来的顺序 和 插入进来的顺序相同~~

Python中的字典,不是单纯的一个哈希表

keys 获取字典中的所有 key

values 获取字典中的所有value

items 获取字典中的所有键值对~

a = {"id": 1,"name":"zhangsan","score":90,
}print(a.keys())
print(a.values())
print(a.items())# 运行结果:
# dict_keys(['id', 'name', 'score'])
# dict_values([1, 'zhangsan', 90])
# dict_items([('id', 1), ('name', 'zhangsan'), ('score', 90)])

keys 和 values 返回的结果,看起来像列表,又不完全是~~

自定义类型~~

使用的时候也可以把它当作列表来使用~~

items返回的 首先是一个列表一样的结构,里面每个元素又是一个元组,元组里面包含了键和值.

so 可以利用类似于自定义读取利用for方法去读取它的值一样去遍历取出,如下:

a = {"id": 1,"name":"zhangsan","score":90,
}for key,value in a.items():print(key,value)# 运行结果:# id 1# name zhangsan# score 90

可哈希的类型

哈希的概念
哈希技术是一种单向加密技术,也就是说,它可以将任何长度的原始消息转换成一个特定长度的哈希值,但无法从哈希值反推出原始消息。

哈希函数通常具有以下特点

- 压缩性:无论输入消息的长度多长,产生的哈希值长度固定。

- 易计算性:计算哈希值的操作很容易,即使处理的数据量很大。

- 抗碰撞性:难以找到两个不同的输入消息,其哈希值相同,也称为“哈希冲突”。

哈希技术近年来在越来越多的领域中得到了广泛的应用,比如密码学中的数字签名、身份认证、密码存储等,还有数据完整性校验、指纹识别、电子商务中的信任机制等

在 python 里专门提供了一个 hash 函数~

print(hash(0))
print(hash(3.14))
print(hash("hello"))
print(hash(True))# # 运行结果:
# 0
# 322818021289917443
# -5961696303172855508
# 1

通过上面代码运行结果可知:整数,浮点数,字符串,布尔值,元组以计算哈希值.--->可作为key

# 有的类型是不能计算哈希值的.
print(hash([1,2,3]))# 运行结果:
# TypeError: unhashable type: 'list'
print(hash({}))# # 运行结果:
# # TypeError: unhashable type: 'dict'

通过上面代码运行结果可知,列表,字典,不可以哈希.

summary:不可变(整数,浮点数,字符串,布尔值,元组)的对象可哈希,

                可变(字典,列表)的对象不可哈希

                 字典,列表,元组 在python中是非常常用的 内置类型~

                 相比于 int, str, float...

                 它们内部可以再包含其它元素~

                 它们属于 容器/集合类~

🍒字典的知识点就分享到这里啦~🍒

🍒喜欢就一键三连支持一下吧~🍒

🍒谢谢家人们!🍒

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/99802.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

NLP(2)--Transformer

目录 一、Transformer概述 二、输入和输出 三、Encoder 四、Decoder 五、正则化处理 六、对于结构的改进? 七、AT vs NAT 八、Cross-attention 一、Transformer概述 Transformer模型发表于2017年Google团队的Attention is All you need这篇论文,…

SpringMVC(一)

1.SpringMVC简介 1.1 什么是MVC MVC是一种软件架构的思想,将软件按照模型、视图、控制器来划分 M:Model,模型层,指工程中的JavaBean,作用是处理数据 JavaBean分为两类: 一类称为实体类Bean:专门存储业务逻辑的,如Student、Us…

2605. 从两个数字数组里生成最小数字

诸神缄默不语-个人CSDN博文目录 力扣刷题笔记 文章目录 1. 我自己写的2. 题解2.1 用哈希表来判断重复数字2.2 用位运算判断重复数字2.3 快排 1. 我自己写的 解法:如果有重复数字就直接输出最小的重复数字,如果没有就直接把两个列表里最小的数字拼在一起…

面试设计模式-责任链模式

一 责任链模式 1.1 概述 在进行请假申请,财务报销申请,需要走部门领导审批,技术总监审批,大领导审批等判断环节。存在请求方和接收方耦合性太强,代码会比较臃肿,不利于扩展和维护。 1.2 责任链模式 针对…

java面试之ThreadLocal问题

什么是ThreadLocal,它的基本用法是什么 简单来说就是能在多线程中保持变量独立的线程对象 不用Threadlocal多线程访问同一个变量会出现的问题 package com.pxx;/*** Created by Administrator on 2023/9/3.*/ public class Demo1 {private String v1;public String getV1() …

详解IP协议

在介绍IP协议之前,先抛出一个概念:IP地址的作用——定位主机,具有将数据从主机A跨网络传输到主机B的能力,有了TCP提供的策略,例如滑动窗口、拥塞控制等,IP去执行它,所以我们通常叫TCP/IP协议&am…

降噪音频转录 Krisp: v1.40.7 Crack

主打人工智能降噪服务的初创公司「Krisp」近期宣布推出音频转录功能,能对电话和视频会议进行实时设备转录。该软件还整合的ChatGPT,以便快速总结内容,开放测试版于今天上线。 随着线上会议越来越频繁,会议转录已成为团队工作的重…

QT DAY7

主要完成多人聊天室,注册与登录使用sql3数据库进行对密码的保存,避免了用户重复登录、错误密码登录、重复注册的问题,之后使用TCP通信,连接上服务器后可在聊天室多人交流

十四、MySQL(DCL)如何实现用户的简单管理?配置用户?

1、DCL语句: 要学习DCL语言,就要清楚DCL语言是用来干什么的,首先DCL语言英文全称是Data Control Language,是数据控制语言,主要用来管理数据库用户、控制数据库的访问权限/ 2、DCL的基础语法: (…

SpringBoot通过@Cacheable注解实现缓存功能

目录 一、Spring从3.1开始支持Cache二、Cacheable常用属性1、value/cacheNames2、key3、condition4、unless5、keyGenerator6、sync7、cacheManager 三、整合步骤1、加入pom2、启动类加EnableCaching注解3、controller或service加Cacheable注解即可 四、代码实例五、Spring Boo…

unity面试题(性能优化篇)

CPU 预处理、缓存数据 注释空的unity函数 运算cpu->gpu 减少昂贵计算(开方) 限制帧数 加载(预加载、分帧加载、异步加载、对象池) 慎用可空类型比较 避免频繁计算(分帧、隔帧) 算法优化 变体收集预热 使用clear操作代替容器的new操作 unity spine使用二进制格式…

Unity中Shader的变体shader_feature

文章目录 前言一、变体的类型1、multi_compile —— 无论如何都会被编译的变体2、shader_feature —— 通过材质的使用情况来决定是否编译的变体 二、使用 shader_feature 来控制 shader 效果的变化1、首先在属性面板暴露一个开关属性,用于配合shader_feature来控制…