Python字典和集合操作指南:创建、获取值、修改和删除键值对,复制和遍历方法全解析

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: Python字典和集合操作指南:创建、获取值、修改和删除键值对,复制和遍历方法全解析

字典(dict)


字典是一种新的数据结构,被称为映射(mapping)。它类似于列表,都用于存储对象。然而,相比列表,字典在查询数据时性能更佳。这是因为在字典中,每个元素都有一个唯一的名字,通过这个名字可以快速查找到指定的元素。


字典由多个键值对(key-value)构成,其中每个键值对都有一个唯一的键和对应的值。通过键可以快速查询到对应的值。创建字典的方式是使用大括号 {},并提供键值对。键可以是任意不可变对象(例如 int、str、bool、tuple 等),但通常我们使用字符串作为键。


创建字典


使用{}来创建字典,语法:{k1:v1,k2:v2,k3:v3}。

# 使用{}
d = {'name':'孙悟空', 'age':18, 'gender':'男'}

也可以使用dict()函数来创建字典,每一个参数都是一个键值对,参数名就是键,参数值就是值(这种方式创建的字典,key都是字符串)。

# 使用dict()函数来创建字典
d = dict(name='孙悟空', age=18, gender='男')

还可以将一个包含双值子序列的序列转换为字典,双值序列指的是序列中只有两个值,如[1,2]('a',3)'ab'等。子序列指的是序列中的元素也是序列的情况,比如[(1,2),(3,5)]

d = dict([('name', '孙悟饭'), ('age', 18)])

获取字典中的值


可以使用键来获取字典中的值,语法为:d[key]。如果键不存在,会抛出异常KeyError

print(d['age'])

可以使用get(key[, default])方法来根据键获取字典中的值。如果键在字典中不存在,则会返回None,也可以指定一个默认值作为第二个参数,当获取不到值时返回默认值。

print(d.get('name'))
print(d.get('hello', '默认值'))

修改字典


可以使用d[key] = value来修改字典中的键值对。如果键存在,则会覆盖其对应的值;如果键不存在,则会添加新的键值对。

d['name'] = 'sunwukong'  # 修改字典的key-value
d['address'] = '花果山'  # 向字典中添加key-value

另外,还可以使用setdefault(key[, default])方法向字典中添加键值对。如果键已经存在于字典中,则返回键对应的值,不会对字典做任何操作;如果键不存在,则向字典中添加该键,并设置对应的值

result = d.setdefault('name', '猪八戒')
result = d.setdefault('hello', '猪八戒')

还可以使用update([other])方法将其他字典中的键值对添加到当前字典中。如果有重复的键,则后面的键值对会替换当前的。

d = {'a': 1, 'b': 2, 'c': 3}
d2 = {'d': 4, 'e': 5, 'f': 6, 'a': 7}
d.update(d2)

删除字典中的键值对


可以使用del关键字删除字典中的键值对。

del d['a']
del d['b']

还可以使用popitem()方法随机删除字典中的一个键值对,一般会删除最后一个键值对。删除后,该方法会将删除的键值对作为返回值返回,返回值是一个元组,包含两个元素,第一个元素是被删除的键,第二个元素是被删除的值。

result = d.popitem()

另外,还可以使用pop(key[, default])方法根据键删除字典中的键值对。该方法会返回被删除的值。如果删除不存在的键,会抛出异常。如果指定了默认值,并且删除的键不存在,则不会报错,而是直接返回默认值

result = d.pop('d')
result = d.pop('z', '这是默认值')

此外,可以使用clear()方法来清空字典中的键值对。

d.clear()

复制字典


可以使用copy()方法对字典进行浅复制。复制后的对象和原对象是独立的,修改一个不会影响另一个。需要注意的是,浅复制只会复制对象内部的值,对于值也是可变对象的情况,它们不会被复制。

d = {'a': 1, 'b': 2, 'c': 3}
d2 = d.copy()
d = {'a': {'name': '孙悟空', 'age': 18}, 'b': 2, 'c': 3}
d2 = d.copy()
d2['a']['name'] = '猪八戒'
print('d =', d, id(d))
print('d2 =', d2, id(d2))

字典推导式


与列表推导式类似,Python 还支持使用字典推导式创建字典。

# 创建一个包含数字的字典
d = {i: i**2 for i in range(5)}
print(d)  # 输出:{0: 0, 1: 1, 2: 4, 3: 9, 4: 16}

遍历字典


遍历字典是指依次访问字典中的每一个键值对。在Python中,有几种方法可以实现字典的遍历操作。


使用keys()方法


keys()方法会返回字典的所有键。我们可以通过遍历键来获取字典中的每个键值对。


示例代码:

d = {'name':'孙悟空','age':18,'gender':'男'}
for k in d.keys():
    print(k, d[k])

使用keys()方法可以获取字典中的所有键,然后通过遍历键来获取每个键值对的值。


使用values()方法


values()方法会返回字典的所有值。我们可以通过遍历值来获取字典中的每个键值对。


示例代码:

d = {'name':'孙悟空','age':18,'gender':'男'}
for v in d.values():
    print(v)

使用values()方法可以获取字典中的所有值,然后通过遍历值来访问每个键值对的值。


使用items()方法


items()方法会返回字典中的所有项,每一项是一个包含键和值的双值子序列。


示例代码:

d = {'name':'孙悟空','age':18,'gender':'男'}
for k, v in d.items():
    print(k, '=', v)

使用items()方法可以获取字典中的所有项,然后通过遍历项来获取每个键值对的键和值。


小结


字典是一种非常灵活的数据结构,可以用于存储各种类型的数据。通过键值对的方式,我们可以快速地查找、添加、修改和删除元素。此外,字典还支持字典推导式等高级用法,可以帮助我们更加方便地操作数据,同时你可以根据具体需求选择合适的方法进行遍历字典。


集合(set)


集合和列表非常相似,不同点如下:


  1.集合中只能存储不可变对象


  2.集合中存储的对象是无序的,不按元素的插入顺序保存


  3.集合中不能存在重复的元素


创建集合


可以使用{}来创建集合:

s = {10, 3, 5, 1, 2, 1, 2, 3, 1, 1, 1, 1}  # <class 'set'>

注意,集合中不能包含可变对象,例如列表:

# s = {[1, 2, 3], [4, 6, 7]}  # TypeError: unhashable type: 'list'

可以使用set()函数来创建集合:

s = set()  # 空集合

还可以通过set()将序列和字典转换为集合:

s = set([1, 2, 3, 4, 5, 1, 1, 2, 3, 4, 5])
s = set('hello')
s = set({'a': 1, 'b': 2, 'c': 3})  # 只包含字典中的键

集合操作


可以使用以下操作来处理集合:


 ▪使用innot in来检查集合中的元素是否存在


 ▪使用len()来获取集合中元素的数量


 ▪使用add()向集合中添加元素


 ▪使用update()将一个集合中的元素添加到当前集合中


 ▪使用pop()随机删除并返回一个集合中的元素


 ▪使用remove()删除集合中的指定元素


 ▪使用clear()清空集合


 ▪使用copy()进行浅复制


示例代码:

s = {'a', 'b', 1, 2, 3, 1}
print('c' in s)  # False
print(len(s))
s.add(10)
s.add(30)
s2 = set('hello')
s.update(s2)
s.update((10, 20, 30, 40, 50))
s.update({10: 'ab', 20: 'bc', 100: 'cd', 1000: 'ef'})
result = s.pop()
s.remove(100)
s.remove(1000)
s.clear()
print(result)
print(s, type(s))

集合运算


在对集合进行运算时,不会影响原来的集合,而是返回一个运算结果。


示例代码:

s = {1, 2, 3, 4, 5}
s2 = {3, 4, 5, 6, 7}
result = s & s2  # 交集运算
result = s | s2  # 并集运算
result = s - s2  # 差集
result = s ^ s2  # 异或集
a = {1, 2, 3}
b = {1, 2, 3, 4, 5}
result = a <= b  # 检查一个集合是否是另一个集合的子集
result = {1, 2, 3} <= {1, 2, 3}  # True
result = {1, 2, 3, 4, 5} <= {1, 2, 3}  # False
result = {1, 2, 3} < {1, 2, 3}  # 检查一个集合是否是另一个集合的真子集
result = {1, 2, 3} < {1, 2, 3, 4, 5}  # True
result = a >= b  # 检查一个集合是否是另一个的超集
result = a > b  # 检查一个集合是否是另一个的真超集
print('result =', result)

以上是关于集合的一些基本操作和运算,总结如下。


小结


当使用集合时,需要注意以下几点:


 1.集合是一种无序且元素唯一的数据结构。


 2.可以使用{}set()函数创建集合。


 3.集合中只能存储不可变的对象,不能包含可变对象。


 4.可以使用innot in来检查集合中的元素是否存在。


 5.使用len()获取集合中元素的数量。


 6.使用add()向集合中添加元素,使用update()将一个集合中的元素添加到当前集合中。


 7.使用pop()随机删除并返回一个集合中的元素,使用remove()删除集合中的指定元素,使  用clear()清空集合。

 

 8.使用copy()进行浅复制。


 9.集合可以进行交集运算(&)、并集运算(|)、差集运算(-)和异或集运算(^)。


 10.可以使用<=<>=>来比较两个集合的关系,如子集、超集和真子集等。


总结起来,集合是一种非常有用的数据结构,适用于需要存储一组元素并进行快速元素查找和去重的场景。

相关文章
|
5天前
|
监控 算法 安全
内网桌面监控软件深度解析:基于 Python 实现的 K-Means 算法研究
内网桌面监控软件通过实时监测员工操作,保障企业信息安全并提升效率。本文深入探讨K-Means聚类算法在该软件中的应用,解析其原理与实现。K-Means通过迭代更新簇中心,将数据划分为K个簇类,适用于行为分析、异常检测、资源优化及安全威胁识别等场景。文中提供了Python代码示例,展示如何实现K-Means算法,并模拟内网监控数据进行聚类分析。
28 10
|
23天前
|
存储 算法 安全
控制局域网上网软件之 Python 字典树算法解析
控制局域网上网软件在现代网络管理中至关重要,用于控制设备的上网行为和访问权限。本文聚焦于字典树(Trie Tree)算法的应用,详细阐述其原理、优势及实现。通过字典树,软件能高效进行关键词匹配和过滤,提升系统性能。文中还提供了Python代码示例,展示了字典树在网址过滤和关键词屏蔽中的具体应用,为局域网的安全和管理提供有力支持。
50 17
|
26天前
|
运维 Shell 数据库
Python执行Shell命令并获取结果:深入解析与实战
通过以上内容,开发者可以在实际项目中灵活应用Python执行Shell命令,实现各种自动化任务,提高开发和运维效率。
54 20
|
1月前
|
数据采集 供应链 API
Python爬虫与1688图片搜索API接口:深度解析与显著收益
在电子商务领域,数据是驱动业务决策的核心。阿里巴巴旗下的1688平台作为全球领先的B2B市场,提供了丰富的API接口,特别是图片搜索API(`item_search_img`),允许开发者通过上传图片搜索相似商品。本文介绍如何结合Python爬虫技术高效利用该接口,提升搜索效率和用户体验,助力企业实现自动化商品搜索、库存管理优化、竞品监控与定价策略调整等,显著提高运营效率和市场竞争力。
83 3
|
1月前
|
JSON 监控 安全
深入理解 Python 的 eval() 函数与空全局字典 {}
`eval()` 函数在 Python 中能将字符串解析为代码并执行,但伴随安全风险,尤其在处理不受信任的输入时。传递空全局字典 {} 可限制其访问内置对象,但仍存隐患。建议通过限制函数和变量、使用沙箱环境、避免复杂表达式、验证输入等提高安全性。更推荐使用 `ast.literal_eval()`、自定义解析器或 JSON 解析等替代方案,以确保代码安全性和可靠性。
42 2
|
2月前
|
数据采集 JSON API
如何利用Python爬虫淘宝商品详情高级版(item_get_pro)API接口及返回值解析说明
本文介绍了如何利用Python爬虫技术调用淘宝商品详情高级版API接口(item_get_pro),获取商品的详细信息,包括标题、价格、销量等。文章涵盖了环境准备、API权限申请、请求构建和返回值解析等内容,强调了数据获取的合规性和安全性。
|
2月前
|
数据挖掘 vr&ar C++
让UE自动运行Python脚本:实现与实例解析
本文介绍如何配置Unreal Engine(UE)以自动运行Python脚本,提高开发效率。通过安装Python、配置UE环境及使用第三方插件,实现Python与UE的集成。结合蓝图和C++示例,展示自动化任务处理、关卡生成及数据分析等应用场景。
173 5
|
2月前
|
人工智能 数据可视化 数据挖掘
探索Python编程:从基础到高级
在这篇文章中,我们将一起深入探索Python编程的世界。无论你是初学者还是有经验的程序员,都可以从中获得新的知识和技能。我们将从Python的基础语法开始,然后逐步过渡到更复杂的主题,如面向对象编程、异常处理和模块使用。最后,我们将通过一些实际的代码示例,来展示如何应用这些知识解决实际问题。让我们一起开启Python编程的旅程吧!
|
2月前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
2月前
|
Unix Linux 程序员
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
126 80

热门文章

最新文章