前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PYTHON知识点学习-字典

PYTHON知识点学习-字典

作者头像
用户10920432
发布2024-01-18 15:11:42
1190
发布2024-01-18 15:11:42
举报
文章被收录于专栏:Python数据结构与算法

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

目录

字典的介绍及创建

字典查找key

dictionary&list对比

字典的新增修改删除

理解字典操作的效率

字典的遍历

可哈希的类型


字典的介绍及创建

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

键(key)

值(value)

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

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

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

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

代码语言:javascript
复制
#1.创建字典
a = {}
print(type(a))
b = dict()
print(type(b))
代码语言:javascript
复制
#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 对类型无约束

代码语言:javascript
复制
a ={
    "id":1 ,
    "name" : "zhangsan",
    }

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

字典查找key

代码语言:javascript
复制
#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

代码语言:javascript
复制
#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 中,可以通过多层索引来查找嵌套字典中最里面的值

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

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

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

代码语言:javascript
复制
phone_number = my_dict['contacts']['phone']['mobile']
print(phone_number)  # 输出: '123-456-7890'

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

代码语言:javascript
复制
phone_number = my_dict.get('contacts', {}).get('phone', {}).get('mobile')
print(phone_number)  # 输出: '123-456-7890'

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

dictionary&list对比

字典的新增修改删除

代码语言:javascript
复制
#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() 方法来替换字典中的键值对。该方法接收一个字典作为参数,将该字典中的键值对替换到原字典中对应的键上。

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

代码语言:javascript
复制
dict1 = {"a": 1, "b": 2, "c": 3}
dict2 = {"b": 4, "d": 5}

dict1.update(dict2)

print(dict1)

输出结果为:

代码语言:javascript
复制
{'a': 1, 'b': 4, 'c': 3, 'd': 5}

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

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

理解字典操作的效率

遍历指的是:能够把一个可迭代对象,里面包含的元素依次取出,并进行一些操作.整个过程要求不重不漏. 字典被设计出来的初衷,不是为了遍历,而是为了增删查改. 字典是 哈希表,进行增删改查操作,效率度非常高!! 而字典的遍历则效率就要差一些. 哈希表 这个结构被设计的非常巧妙,能够以"常数级"时间复杂度来完成增删改查~ "常数级":无论字典中有多少元素~ 新增,修改,查找 操作都是固定时间,不会因为元素多了,操作就慢了~ ❗❗❗哈希表非常重要,后面会继续深入学习发博文

字典的遍历

代码语言:javascript
复制
#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 获取字典中的所有键值对~

代码语言:javascript
复制
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方法去读取它的值一样去遍历取出,如下:

代码语言:javascript
复制
a = {
    "id": 1,
    "name":"zhangsan",
    "score":90,
}

for key,value in a.items():
    print(key,value)

    # 运行结果:
    # id 1
    # name zhangsan
    # score 90

可哈希的类型

哈希的概念 哈希技术是一种单向加密技术,也就是说,它可以将任何长度的原始消息转换成一个特定长度的哈希值,但无法从哈希值反推出原始消息。 哈希函数通常具有以下特点: - 压缩性:无论输入消息的长度多长,产生的哈希值长度固定。 - 易计算性:计算哈希值的操作很容易,即使处理的数据量很大。 - 抗碰撞性:难以找到两个不同的输入消息,其哈希值相同,也称为“哈希冲突”。 哈希技术近年来在越来越多的领域中得到了广泛的应用,比如密码学中的数字签名、身份认证、密码存储等,还有数据完整性校验、指纹识别、电子商务中的信任机制等

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

代码语言:javascript
复制
print(hash(0))
print(hash(3.14))
print(hash("hello"))
print(hash(True))

# # 运行结果:
# 0
# 322818021289917443
# -5961696303172855508
# 1

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

代码语言:javascript
复制
# 有的类型是不能计算哈希值的.
print(hash([1,2,3]))

# 运行结果:
# TypeError: unhashable type: 'list'
代码语言:javascript
复制
print(hash({}))

# # 运行结果:
# # TypeError: unhashable type: 'dict'

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

summary:不可变(整数,浮点数,字符串,布尔值,元组)的对象可哈希, 可变(字典,列表)的对象不可哈希 字典,列表,元组 在python中是非常常用的 内置类型~ 相比于 int, str, float... 它们内部可以再包含其它元素~ 它们属于 容器/集合类~

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

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

🍒谢谢家人们!🍒

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-09-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 字典的介绍及创建
  • 字典查找key
  • dictionary&list对比
  • 字典的新增修改删除
  • 理解字典操作的效率
  • 字典的遍历
  • 可哈希的类型
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档