Python 基础语法:基本数据类型(字典)

news2024/11/18 18:19:02

为什么这个基本的数据类型被称作字典呢?这个是因为字典这种基本数据类型的一些行为和我们日常的查字典过程非常相似。

通过汉语字典查找汉字,首先需要确定这个汉字的首字母,然后再通过这个首字母找到我们所想要的汉字。这个过程其实就代表了字典的一个特性:每一组汉字都有一个唯一的标识(首字母)。

对于 Python 中的字典来说,它通常都有一个key,表示字典的关键字。还有一个 value ,表示关键字所代表的相应的数据的值。我们通常对字典做的最多的一个操作就是通过 key 关键字,找到这个 key 所代表的 value 值。

1  字典的定义和创建

1.1  字典的定义

字典(dictionary)是Python中的一种可变的数据类型,它用于存储键(key)和值(value)的映射关系。键必须是唯一的,而值可以是任何数据类型。

1.2  字典的创建

1.2.1  使用花括号 {} 创建字典

在Python中,您可以使用花括号 {} 来直接创建一个字典。字典的键和值之间使用冒号 : 分隔,而不同的键值对之间使用逗号 , 分隔。

# 使用花括号 {} 创建字典  
dict1 = {'name': 'Alice', 'age': 25, 'city': 'New York'}  

 在这个例子中,dict1 是一个包含三个键值对的字典:'name' 对应 'Alice''age' 对应 25'city' 对应 'New York'

1.2.2  使用 dict() 函数创建字典

除了使用花括号外,还可以使用 dict() 函数来创建字典。dict() 函数接受一系列的键值对作为参数,并返回一个新的字典。这些键值对通常是以关键字参数的形式传递的。

# 使用 dict() 函数创建字典
dict2 = dict(name='Bob', age=30, city='Los Angeles')
print(dict2)  # 结果:{'name': 'Bob', 'age': 30, 'city': 'Los Angeles'}

1.3  字典的特性

  • 键的唯一性:字典的键必须是唯一的。如果您尝试添加具有相同键的键值对,新值会覆盖旧值。
  • 键的类型:键可以是任何不可变类型,如整数、浮点数、字符串或元组(只要元组中的元素也是不可变的)。但列表、集合和其他可变类型不能用作字典的键。
  • 值的类型:与键不同,字典的值可以是任何Python对象,包括可变类型如列表或字典。
  • 动态性:字典是动态的,这意味着您可以在创建字典后随时添加、删除或修改键值对。

2. 字典的常用操作

字典是Python中用于存储键值对的数据结构,其常用操作包括:

2.1  查看元素

2.1.1  使用字典的键(key)获取对应的值(value)
# 创建一个字典,其中包含三个键值对  
my_dict = {'apple': 1, 'banana': 2, 'cherry': 3}  
  
# 使用字典的键 'apple' 来获取对应的值  
# 如果键存在,则返回该键对应的值;如果键不存在,则会引发 KeyError 异常  
value_of_apple = my_dict['apple']  
print(value_of_apple)  # 输出: 1  
  
try:  
    # 尝试使用字典的键 'orange' 来获取对应的值  
    # 因为 'orange' 这个键在字典中不存在,所以会引发 KeyError 异常  
    value_of_orange = my_dict['orange']  
except KeyError:  
    # 当捕获到 KeyError 异常时,执行此处的代码  
    print("键 'orange' 不存在于字典中。")  
    value_of_orange = None  # 可以设置一个默认值  
  

在这个例子中,我添加了一个try-except块来捕获尝试访问不存在键时引发的KeyError异常。这样做可以帮助我们优雅地处理这种情况,而不是让程序崩溃。

2.1.2  使用get()方法获取指定键的值
# 创建一个字典,其中包含三个键值对  
my_dict = {'apple': 1, 'banana': 2, 'cherry': 3}  

# 使用 get 方法来获取值  
# 如果键存在,则返回该键对应的值;如果键不存在,则返回 None(或者指定的默认值)  
# 使用 get 方法不会引发异常  
value_of_orange_get = my_dict.get('orange')  
print(value_of_orange_get)  # 输出: None  
  
# 你也可以使用 get 方法来指定一个默认值,当键不存在时返回这个默认值  
value_of_orange_default = my_dict.get('orange', '默认值')  
print(value_of_orange_default)  # 输出: '默认值'

上例中,使用get方法的第二个参数来指定一个默认值,当键不存在时返回这个默认值。

在实际编程中,通常推荐使用get方法来避免可能的异常,特别是当你不确定一个键是否存在于字典中时。当然,如果你确定键一定存在,直接通过键访问也是可以的,因为这会让代码更简洁。不过,在涉及用户输入或不确定的数据源时,使用get方法会更加安全。

2.2  修改元素

2.2.1  修改已存在的键值对

要修改Python字典中已存在的键值对,你可以直接通过键来访问并重新赋值。这样,原来的值就会被新的值所替换。

# 创建一个字典  
my_dict = {'apple': 1, 'banana': 2, 'cherry': 3}  
  
# 打印原始字典  
print("原始字典:", my_dict)  # 原始字典: {'apple': 1, 'banana': 2, 'cherry': 3}  
  
# 修改已存在的键值对  
# 将 'apple' 对应的值从 1 修改为 10  
my_dict['apple'] = 10  
  
# 打印修改后的字典  
print("修改后的字典:", my_dict)  # 修改后的字典: {'apple': 10, 'banana': 2, 'cherry': 3}
2.2.2   修改一个不存在的键值对

注意,如果您尝试修改一个不存在的键的值,并且该键也不存在于字典中,Python 不会像一些其他语言那样抛出一个错误。相反,它会默默地添加这个新的键值对到字典中。

# 创建一个包含一些键值对的字典  
my_dict = {'banana': 2, 'cherry': 3}  
  
# 修改已存在的键值对(如果它存在的话)  
# 假设这里我们要修改键为 'apple' 的值,但实际上这个键在初始字典中并不存在  
my_dict['apple'] = 10  
  
# 输出修改后的字典  
print(my_dict)  # 输出可能是: {'banana': 2, 'cherry': 3, 'apple': 10}

如果您想要修改一个可能不存在的键的值,并且希望在键不存在时避免添加新键,您可以使用 dict.get() 方法结合条件判断来实现: 

# 假设我们想要修改键为 'apple' 的值,但如果它不存在,我们不想添加它  
value = my_dict.get('apple')  # 尝试获取键 'apple' 的值,如果不存在则返回 None  
if value is not None:  
    my_dict['apple'] = new_value  # new_value 是您想要设置的新值

在这个例子中,如果键 'apple' 不存在,my_dict.get('apple') 将返回 None,因此不会执行修改操作。如果键存在,那么它的值将被更新为 new_value

2.3  添加元素

如果key不存在,通过 字典名 [key值] = 值 的方式可以添加新的键值对。

# 添加一个新的键值对  
my_dict['date'] = '2023-09-25'  
print(my_dict)  # 输出: {'apple': 10, 'banana': 2, 'cherry': 3, 'date': '2023-09-25'}

2.4  删除元素

当使用Python字典时,可以使用不同的方法来删除键值对或整个字典。

2.4.1  删除指定的键值对

使用 del 语句删除指定的键值对

# 创建一个字典  
my_dict = {'apple': 1, 'banana': 2, 'cherry': 3}  
  
# 打印原始字典  
print("原始字典:", my_dict)  #  原始字典: {'apple': 1, 'banana': 2, 'cherry': 3}
  
# 删除指定的键值对  
del my_dict['banana']  
  
# 打印修改后的字典  
print("删除 'banana' 键值对后的字典:", my_dict)

# 返回结果:原始字典: {'apple': 1, 'banana': 2, 'cherry': 3}
2.4.2  删除整个字典

使用 del 语句,还可以删除整个字典。

# 创建一个字典  
my_dict = {'apple': 1, 'banana': 2, 'cherry': 3}  
  
# 打印原始字典  
print("原始字典:", my_dict)  
  
# 删除整个字典  
del my_dict  
  
# 尝试打印字典(将会引发NameError)  
try:  
    print("删除后的字典:", my_dict)  
except NameError:  
    print("字典已被删除,无法打印")

在这个例子中,我们使用 del 语句删除了整个 my_dict 字典。之后尝试打印字典将会导致 NameError,因为该字典已经被删除了。

请注意,在删除字典或字典中的元素之后,如果你尝试访问它们,将会引发错误(KeyError 对于键值对,NameError 对于整个字典)。因此,在删除元素或字典后,确保不再使用它们,或者在使用前进行检查以避免错误。

 2.4.3  删除并返回指定key的值

使用 pop 方法可以删除指定键的键值对,并且返回了被删除的值。

# 创建一个字典  
my_dict = {'apple': 1, 'banana': 2, 'cherry': 3}  
  
# 打印原始字典  
print("原始字典:", my_dict)  
#  返回:原始字典: {'apple': 1, 'banana': 2, 'cherry': 3}  
  
# 删除并返回指定key的值  
removed_value = my_dict.pop('apple')  
  
# 打印被删除的值和修改后的字典  
print("被删除的值:", removed_value)  
#  返回:1
print("删除 'apple' 键值对后的字典:", my_dict)  
#  返回:删除 'apple' 键值对后的字典: {'banana': 2, 'cherry': 3}

2.5  清空字典

使用 字典名.clear() 可以清空字典中的所有键值对。

my_dict = {'apple': 1, 'banana': 2, 'cherry': 3} 

# 清空字典  
my_dict.clear()  
print(my_dict)  # 输出: {}

2.6  测量键值对的长度或个数

使用len(字典名)可以获取字典中键值对的个数。

my_dict = {'apple': 1, 'banana': 2, 'cherry': 3} 

# 获取字典的长度  
length_of_dict = len(my_dict)  
print(length_of_dict)  # 输出: 3

2.7  返回字典的键、值或键值对列表

2.7.1  获取字典中所有的键

使用字典名.keys()可以获取字典中所有的键。

# 创建一个新的字典  
new_dict = {'a': 100, 'b': 200, 'c': 300}  
  
# 获取所有的键  
keys = new_dict.keys()  
print(keys)  # 输出: dict_keys(['a', 'b', 'c'])  

.keys() 方法返回的是一个视图对象,它显示了字典中所有的键。输出 dict_keys(['a', 'b', 'c']) 表示这是一个键的视图,包含了 'a''b''c' 这三个键。 

2.7.2  获取字典中所有的值

使用字典名.values()可以获取字典中所有的值。

# 创建一个新的字典  
new_dict = {'a': 100, 'b': 200, 'c': 300}  

  
# 获取所有的值  
values = new_dict.values()  
print(values)  # 输出: dict_values([100, 200, 300])  

.values() 方法返回的是一个视图对象,它显示了字典中所有的值。输出 dict_values([100, 200, 300]) 表示这是一个值的视图,包含了 100200300 这三个值。 

2.7.3  获取字典中所有的健值对

使用字典名.items()可以获取字典中所有的键值对,以元组的形式存放在列表中。

# 创建一个新的字典  
new_dict = {'a': 100, 'b': 200, 'c': 300}  

  
# 获取所有的键值对  
items = new_dict.items()  
print(items)  # 输出: dict_items([('a', 100), ('b', 200), ('c', 300)])

.items() 方法返回的是一个视图对象,它显示了字典中所有的键值对。输出 dict_items([('a', 100), ('b', 200), ('c', 300)]) 表示这是一个键值对的视图,包含了 ('a', 100)('b', 200)('c', 300) 这三个键值对。

请注意,这些视图对象(keysvaluesitems)是动态的,它们会随着字典的改变而自动更新。但是,它们不是列表,因此如果你需要固定的列表形式,可以使用 list() 函数将它们转换为列表:

keys_list = list(keys)  
values_list = list(values)  
items_list = list(items)

这样转换后,你就可以得到一个静态的列表,即使字典之后发生变化,这个列表也不会自动更新。

2.8  字典的遍历

遍历字典的键:for key in 字典名

遍历字典的值:for value in 字典名.values()。

同时遍历字典的键和值:for key, value in 字典名.items()。

new_dict = {'a': 100, 'b': 200, 'c': 300}

# 遍历字典的键
for key in new_dict:
    print(key,end=',')  # 返回:a,b,c,

# 遍历字典的值
for value in new_dict.values():
    print(value,end=',')  # 返回:100,200,300,

# 遍历字典的键值对,并返回元组
for item in new_dict.items():
    print(item,end=',')  # 返回:('a', 100),('b', 200),('c', 300),

# 遍历字典的键值对,并返回键和值
for key,value in new_dict.items():
    print(key,value,end=',')  # 返回:a 100,b 200,c 300,

这些是字典的一些常用操作,通过这些操作,可以对字典进行增删改查等各种处理。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Algorithms 4】算法(第4版)学习笔记 18 - 4.4 最短路径

文章目录 前言参考目录学习笔记0:引入介绍1:APIs1.1:API:加权有向边1.2:Java 实现:加权有向边1.3:API:加权有向图1.4:Java 实现:加权有向图1.5:AP…

NVidia NX 中 ROS serial软件包的安装

自己装的ROS是noetic版本,受限于网络,直接用命令安装串口包不行。于是手动安装了一次。 1 下载源码 git clone https://github.com/wjwwood/serial.git 或者直接在浏览器里面输入 https://github.com/wjwwood/serial.git 2 解压 然后在serial&#xf…

【考研数学】高等数学总结

文章目录 第一章 极限 函数 连续1.1 极限存在准则及两个重要极限1.1.1 夹逼定理1.1.1.1 数列夹逼定理1.1.1.2函数夹逼定理 1.1.2 两个重要极限1.1.2.1 极限公式11.1.2.1.1 证明1.1.2.1.2 数列的单调有界收敛准则1.1.2.1.2.1 二项式定理1.1.2.1.2.2 证明 1.1.2.2 极限公式21.1.2…

未来洞见:亚信安慧AntDB在数据可靠性上的愿景

和国外成熟稳定的商业数据库相比,国产数据库在性能、稳定性、生态等方面存在一定差距,我国数据库的自主可控替换,也不是简单的以库换库,而是用新体系替换旧体系,在架构、研发、上线、运维等方面,全面降低对…

Pyqt5中,QGroupBox组件标题字样(标题和内容样式分开设置)相对于解除继承

Python代码示例: import sys from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QGroupBox, QLabelclass MyApp(QWidget):def __init__(self):super().__init__()# 创建一个 QVBoxLayout 实例layout QVBoxLayout()# 创建 QGroupBox 实例self.grou…

系统分析与设计作业 --- 酒店管理系统(2~3周)

第二周 作业一: (1)需求分析NABCD 我们的项目是一个酒店管理系统,所i对应的NABCD描述 NABCD是一种产品描述框架,用于全面阐述产品的各个方面。其中,N代表需求(Need),描…

5_springboot_shiro_jwt_多端认证鉴权_禁用Cookie

1. Cookie是什么 ​ Cookie是一种在客户端(通常是用户的Web浏览器)和服务器之间进行状态管理的技术。当用户访问Web服务器时,服务器可以向用户的浏览器发送一个名为Cookie的小数据块。浏览器会将这个Cookie存储在客户端,为这个Co…

字符串分割(C++)

经常碰到字符串分割的问题,这里总结下,也方便我以后使用。 一、用strtok函数进行字符串分割 原型: char *strtok(char *str, const char *delim); 功能:分解字符串为一组字符串。 参数说明:str为要分解的字符串&am…

LeetCode每日一题 将有序数组转换为二叉搜索树(分治)

题目描述 给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵平衡二叉搜索树。 示例 1: 输入:nums [-10,-3,0,5,9] 输出:[0,-3,9,-10,null,5] 解释:[0,-10,5,null,-3,null,9] 也将被视…

[RAM] RAM 突发传输(Burst ,Burst size, length) | Burst 读写过程与时序 精讲

主页: 元存储博客 文章目录 前言1. Burst 基本概念含义Burst Width &Burst Length 2. CPU Burst mode3. 总线 burst mode总线的仲裁总线突发传输时序 4. Burst Chop (突发终止)5. Burst Mode 应用什么时候用突发模式 总结 前言 在DMA(直接内存访问&…

MD5算法:密码学中的传奇

title: MD5算法:密码学中的传奇 date: 2024/3/15 20:08:07 updated: 2024/3/15 20:08:07 tags: MD5起源算法原理安全分析优缺点比较技术改进示例代码应用趋势 MD5算法起源: MD5(Message Digest Algorithm 5)算法是由MIT的计算机…

Web框架盘点:好用又实用的技术解析

​随着2024年的临近,我们满怀热情地为新的一年制定计划,探索未来一年可以学习或实现的目标。此时是探索未来一年值得学习的框架、理解其功能和特点的最佳时机。我们将以2023年JavaScript新星为指南,力求保持客观公正的态度。对于每个值得关注…

调皮的String及多种玩法(下部)

👨‍💻作者简介:👨🏻‍🎓告别,今天 📔高质量专栏 :☕java趣味之旅 欢迎🙏点赞🗣️评论📥收藏💓关注 💖衷心的希…

修复 error Delete `␍` prettier/prettier 错误

修复 error Delete ␍ prettier/prettier 错误 问题背景报错信息报错原因解决办法修改CRLF----针对单个文件yarn run lint --fix 一键修复(官方提供) 问题背景 今天在使用 openapi 自动生成前端接口代码的时候,爆了一个类似 eslint 规范的错…

C/C++炸弹人游戏

参考书籍《啊哈,算法》,很有意思的一本算法书,小白也可以看懂,详细见书,这里只提供代码和运行结果。 这里用到的是枚举思想,还有更好地搜索做法。 如果大家有看不懂的地方或提出建议,欢迎评论区…

外包干了9天,技术退步明显。。。。。

先说一下自己的情况,本科生,2018年我通过校招踏入了南京一家软件公司,开始了我的职业生涯。那时的我,满怀热血和憧憬,期待着在这个行业中闯出一片天地。然而,随着时间的推移,我发现自己逐渐陷入…

Django之Cookie

Django之Cookie 目录 Django之Cookie介绍Django操作Cookie设置Cookie浏览器查看Cookie 获取Cookie设置超时Cookie注销Cookie 模拟登录验证登录验证装饰器登录验证装饰器-升级版 介绍 当我们上网使用社交媒体或者购物时,浏览器需要通过一种方式来记住我们。想象一下…

Java宝典-异常

目录 1. 异常的分类1.1 运行时异常1.2 编译时异常 2. 异常的抛出2.1 throw2.2 throws 3. 异常的捕获3.1 try-catch3.2 finally 4. 异常执行的过程5. 自定义异常 在Java中,异常(Exception)是指程序发生不正常的行为,异常其实就是一个一个的类。 1. 异常的…

算法-贪心-122. 糖果传递

题目 有 n个小朋友坐成一圈,每人有 a[i]个糖果。 每人只能给左右两人传递糖果。 每人每次传递一个糖果代价为 1。 求使所有人获得均等糖果的最小代价。 输入格式 第一行输入一个正整数 n,表示小朋友的个数。 接下来 n 行,每行一个整数…

数据结构 之 优先级队列(堆) (PriorityQueue)

🎉欢迎大家观看AUGENSTERN_dc的文章(o゜▽゜)o☆✨✨ 🎉感谢各位读者在百忙之中抽出时间来垂阅我的文章,我会尽我所能向的大家分享我的知识和经验📖 🎉希望我们在一篇篇的文章中能够共同进步!!&…