百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Python元组与字典用法详解_在python中列表,元组,字典的区别

liuian 2025-02-19 12:54 27 浏览

回顾

在上一篇《Python列表详解》,我们介绍了列表的的相关知识,简单回顾一下:

  1. 创建列表:[] 和list()函数两种创建方式
  2. 访问列表元素:listname[i]、listname[start : end : step]、listname[:]
  3. 列表添加元素:append、extend、insert
  4. 列表删除元素:del、pop、remove、clear
  5. 列表查找元素:count、index
  6. 列表反转:reverse
  7. 列表排序:sort-不生成新列表、sorted-生成新列表

一、元组

元组(tuple)是 Python 中另一个重要的序列结构,和列表类似,元组也是由一系列按特定顺序排序的元素组成,列表和元组都是有序序列

1.list列表和tuple元组

元组和列表(list)的不同之处在于:

◆ 列表的元素是可以更改的,包括修改元素值,删除和插入元素,所以列表是可变序列

◆ 而元组一旦被创建,它的元素就不可更改了,所以元组是不可变序列

元组也可以看做是不可变的列表,通常情况下,元组用于保存无需修改的内容。

2.创建元组

Python 提供了两种创建元组的方法:

1) 使用( )直接创建

通过( )创建元组后,一般使用=将它赋值给某个变量,具体格式为:

tuplename = (element1, element2, ..., elementn),例如:

# 通过()创建元组
t1 = ("c", "c++", "java", "python", "ruby")
print(t1)  # ('c', 'c++', 'java', 'python', 'ruby')
# 获取指定索引值
print(t1[2]) # java
# 查询指定范围内是否存在指定值,存在返回索引位置,不存在报错
print(t1.index('java', 0, -1)) # 2

2) 使用tuple()函数创建元组

除了使用( )创建元组外,Python 还提供了一个内置的函数 tuple(),用来将其它数据类型转换为元组类型。例如:

# 使用tuple()函数将其他数据类型转换为元组
list_1 = [1, 3, 5, 7, 9]
t2 = tuple(list_1)  # 列表强转为元组
print(t2)  # (1, 3, 5, 7, 9)
str_1 = "hello world"
t3 = tuple(str_1)  # 字符串强转为元组
print(t3)  # ('h', 'e', 'l', 'l', 'o', ' ', 'w', 'o', 'r', 'l', 'd')
dict_1 = {"name": "chen", "age": 28, "height": "75kg"}
t4 = tuple(dict_1)  # 字典强转为元组
print(t4)  # ('name', 'age', 'height')

二、Python dict字典详解

Python 字典(dict)是 Python 中唯一的映射类型,是一种无序的、可变的序列,它的元素以“键值对(key-value)”的形式存储。字典中,习惯将各元素对应的索引称为键(key),各个键对应的元素称为值(value),键及其关联的值称为“键值对”。总的来说,字典类型所具有的主要特征如下 所示:

1.创建字典

1)使用 { } 创建字典

由于字典中每个元素都包含两部分,分别是键(key)和值(value),因此在创建字典时,键和值之间使用冒号:分隔,相邻元素之间使用逗号,分隔,所有元素放在大括号{ }中。使用{ }创建字典的语法格式如下:dictname = {'key':'value1', 'key2':'value2', ..., 'keyn':valuen}

# 使用{}创建
dict1 = {"name": "tom", "age": 28, "phone": 15252162666}

2)通过 fromkeys() 方法创建字典

Python 中,还可以使用 dict 字典类型提供的 fromkeys() 方法创建带有默认值的字典,具体格式为:

dictname = dict.fromkeys(list,value=None)

其中,list 参数表示字典中所有键的列表(list);value 参数表示默认值,如果不写,则为空值 None。

# 通过 fromkeys() 方法创建字典
c = ['name', 'age', 'weight']
dict5 = dict.fromkeys(c)
dict6 = dict.fromkeys(c, "0")
print(dict5)  # {'name': None, 'age': None, 'weight': None}
print(dict6)  # {'name': '0', 'age': '0', 'weight': '0'}

2)通过 dict() 映射函数创建字典

格式1:dict1 = dict(key1=value1, key2=value2, key3=value3)

格式2:demo = [('two',2), ('one',1), ('three',3)]

dict2 = dict(demo)

格式3:

keys = ['one', 'two', 'three'] # 还可以是字符串或元组

values = [1, 2, 3] # 还可以是字符串或元组

dict3 = dict( zip(keys, values) )

# 使用dict()方法创建
dict2 = dict(age=28, name="tom", city="xuzhou")  # dict(key1=value1,key2=value2)
print(dict2)  # {'age': 28, 'name': 'tom', 'city': 'xuzhou'}

info = (("name", "lucy"), ("age", 28), ("city", "nanjing"), ("number", 227))
dict3 = dict(info)  # 使用dict()方法强制转换二维元组为字典
print(dict3)  # {'name': 'lucy', 'age': 28, 'city': 'nanjing', 'number': 227}

a = [1, 2, 3, 4]
b = ["a", "b", "c", "d"]
dict4 = dict(zip(a, b))  # 使用dict()方法结合zip()方法将等长的列表转换为字典
print(dict4)  # {1: 'a', 2: 'b', 3: 'c', 4: 'd'}

2.访问字典元素

列表和元组是通过下标来访问元素的,而字典不同,它通过键来访问对应的值。

1)Python 访问字典元素的具体格式为:dictname[key]

其中,dictname 表示字典变量的名字,key 表示键名。注意,键必须是存在的,否则会抛出异常。

tup = (['one', 100], ['two', 200], ['three', 300], ['four', 400])
dict1 = dict(tup)
print(dict1['one'])  # 键存在,返回对应value
print(dict1['six'])  # 键不存在,抛出异常

运行结果如下:

2)get() 方法的语法格式为:dictname.get(key[,default])

其中,dictname 表示字典变量的名字;key 表示指定的键;default 用于指定要查询的键不存在时,此方法返回的默认值,如果不手动指定,会返回 None。

# 访问字典元素
dict7 = {'age': 28, 'name': 'tom', 'city': 'xuzhou'}
print(dict7["age"])  # 28
print(dict7.get("age"))  # 28
print(dict7.get("age", 18))  # 28,设置默认返回值,检索到key时,返回key的实际值
print(dict7.get("age111", 18))  # 18,设置默认返回值,未检索到key时,返回默认值

3.字典添加键值对

为字典添加新的键值对很简单,直接给不存在的 key 赋值即可,具体语法格式如下:dictname[key] = value

各个部分的说明:

◆ dictname 表示字典名称。

◆ key 表示新的键。

◆ value 表示新的值,只要是 Python 支持的数据类型都可以。

# 字典添加键值对
dict8 = {'age': 28, 'name': 'tom', 'city': 'xuzhou'}
dict8["number"] = 227  # 如果存在此键,则更新键值,不存在则添加新键值对
print(dict8)  # {'age': 28, 'name': 'tom', 'city': 'xuzhou', 'number': 227}

4.判断字典中是否存在指定键值对

判断字典是否包含指定键值对的键,可以使用 in 或 not in 运算符。

# 判断字典是否包含指定键值对的键
dict9 = {'age': 28, 'name': 'tom', 'city': 'xuzhou'}
assert 'name' in dict9
assert 'address' not in dict9

5.查看dict所有方法

Python 字典的数据类型为 dict,我们可使用 dir(dict) 来查看该类型包含哪些方法

>>> dir(dict)
['clear', 'copy', 'fromkeys', 'get', 'items', 'keys', 'pop', 'popitem', 'setdefault', 'update', 'values']

6.keys()、values() 和 items() 方法

◆ keys() 方法用于返回字典中的所有键(key);

◆ values() 方法用于返回字典中所有键对应的值(value);

◆ items() 用于返回字典中所有的键值对(key-value);

# 返回字典中的所有键
print(dict9.keys())  # dict_keys(['age', 'name', 'city'])
# 返回字典中的所有键的键值
print(dict9.values())  # dict_values([28, 'tom', 'xuzhou'])
# 返回字典中的所有键值对
print(dict9.items())  # dict_items([('age', 28), ('name', 'tom'), ('city', 'xuzhou')])

7.copy()方法-深拷贝与浅拷贝

copy() 方法返回一个字典的拷贝,也即返回一个具有相同键值对的新字典。

深拷贝与浅拷贝:

◆ 浅拷贝:若拷贝的对象是一个可变对象,如字典、列表等,拷贝的只是内存地址,只要其中一个被更改,则拷贝前和拷贝后的对象都会被更改

◆ 深拷贝:deepcopy()方法copy的对象,会新生成一个内存地址,故被拷贝对象的可变元素被更改后不会影响拷贝后的结果

# 拷贝字典
import copy
dict10 = {'age': 28, 'name': 'tom', 'city': ['xuzhou', 'suzhou', 'hangzhou']}
# 浅拷贝:通过dict自带的copy方法
dict11 = dict10.copy()
# 浅拷贝:通过引入copy模块的copy()方法拷贝
dict12 = copy.copy(dict10)
# 深拷贝:通过引入copy模块的deepcopy()方法拷贝
dict13 = copy.deepcopy(dict10)
dict10["city"].remove('xuzhou')
print(dict11)  # {'age': 28, 'name': 'tom', 'city': ['suzhou', 'hangzhou']}
print(dict12)  # {'age': 28, 'name': 'tom', 'city': ['suzhou', 'hangzhou']}
print(dict13)  # {'age': 28, 'name': 'tom', 'city': ['xuzhou', 'suzhou', 'hangzhou']}

8.update() 方法

update() 方法可以使用一个字典所包含的键值对来更新已有的字典。

在执行 update() 方法时,如果被更新的字典中己包含对应的键值对,那么原 value 会被覆盖;如果被更新的字典中不包含对应的键值对,则该键值对被添加进去。

# 更新字典
dict14 = {'age': 28, 'name': 'tom', 'city': ['xuzhou', 'suzhou', 'hangzhou']}
dict14.update({"age": 18})
print(dict14)  # {'age': 18, 'name': 'tom', 'city': ['xuzhou', 'suzhou', 'hangzhou']}
dict14.update({"num": 227})
print(dict14)  # {'age': 18, 'name': 'tom', 'city': ['xuzhou', 'suzhou', 'hangzhou'], 'num': 227}

9.pop() 和 popitem() 方法

pop() 和 popitem() 都用来删除字典中的键值对,不同的是,pop() 用来删除指定的键值对,而popitem() 用来随机删除一个键值对,语法格式如下:

◆ dictname.pop(key)

◆ dictname.popitem()

# 删除字典元素
dict15 = {'age': 18, 'name': 'tom', 'city': ['xuzhou', 'suzhou', 'hangzhou'], 'num': 227}
dict15.pop('age')  # 删除指定键值对
print(dict15)  # {'name': 'tom', 'city': ['xuzhou', 'suzhou', 'hangzhou'], 'num': 227}
pi = dict15.popitem()  # 删除最后一个键值对,返回值是被删除的键值对
print(pi)  # ('num', 227)
print(dict15)  # {'name': 'tom', 'city': ['xuzhou', 'suzhou', 'hangzhou']}
del dict15["city"]  # 通过del删除指定键值对
print(dict15)  # {'name': 'tom'}

10.setdefault() 方法

setdefault() 方法用来返回某个 key 对应的 value,其语法格式如下:

dictname.setdefault(key, defaultvalue=None)

说明,dictname 表示字典名称,key 表示键,defaultvalue 表示默认值(可以不写,不写的话是 None)。

# 字典key设置默认值
dict16 = {'age': 18, 'name': 'tom', 'num': 227}
dict16.setdefault('name', 'lucy')  # 键存在时,不更新
print(dict16)  # {'age': 18, 'name': 'tom', 'num': 227}
dict16.setdefault('city', 'xuzhou')  # 键不存在时,更新字典
print(dict16)  # {'age': 18, 'name': 'tom', 'num': 227, 'city': 'xuzhou'}

总结

列表和元组都是有序序列,字典是无序序列;

列表和字典都是可变序列,元组是不可变序列;

相关推荐

教你把多个视频合并成一个视频的方法

一.情况介绍当你有一个m3u8文件和一个目录,目录中有连续的视频片段,这些片段可以连成一段完整的视频。m3u8文件打开后像这样:m3u8文件,可以理解为播放列表,里面是播放视频片段的顺序。视频片段像这...

零代码编程:用kimichat合并一个文件夹下的多个文件

一个文件夹里面有很多个srt字幕文件,如何借助kimichat来自动批量合并呢?在kimichat对话框中输入提示词:你是一个Python编程专家,完成如下的编程任务:这个文件夹:D:\downloa...

Java APT_java APT 生成代码

JavaAPT(AnnotationProcessingTool)是一种在Java编译阶段处理注解的工具。APT会在编译阶段扫描源代码中的注解,并根据这些注解生成代码、资源文件或其他输出,...

Unit Runtime:一键运行 AI 生成的代码,或许将成为你的复制 + 粘贴神器

在我们构建了UnitMesh架构之后,以及对应的demo之后,便着手于实现UnitMesh架构。于是,我们就继续开始UnitRuntime,以用于直接运行AI生成的代码。PS:...

挣脱臃肿的枷锁:为什么说Vert.x是Java开发者手中的一柄利剑?

如果你是一名Java开发者,那么你的职业生涯几乎无法避开Spring。它如同一位德高望重的老国王,统治着企业级应用开发的大片疆土。SpringBoot的约定大于配置、SpringCloud的微服务...

五年后,谷歌还在全力以赴发展 Kotlin

作者|FredericLardinois译者|Sambodhi策划|Tina自2017年谷歌I/O全球开发者大会上,谷歌首次宣布将Kotlin(JetBrains开发的Ja...

kotlin和java开发哪个好,优缺点对比

Kotlin和Java都是常见的编程语言,它们有各自的优缺点。Kotlin的优点:简洁:Kotlin程序相对于Java程序更简洁,可以减少代码量。安全:Kotlin在类型系统和空值安全...

移动端架构模式全景解析:从MVC到MVVM,如何选择最佳设计方案?

掌握不同架构模式的精髓,是构建可维护、可测试且高效移动应用的关键。在移动应用开发中,选择合适的软件架构模式对项目的可维护性、可测试性和团队协作效率至关重要。随着应用复杂度的增加,一个良好的架构能够帮助...

颜值非常高的XShell替代工具Termora,不一样的使用体验!

Termora是一款面向开发者和运维人员的跨平台SSH终端与文件管理工具,支持Windows、macOS及Linux系统,通过一体化界面简化远程服务器管理流程。其核心定位是解决多平台环境下远程连接、文...

预处理的底层原理和预处理编译运行异常的解决方案

若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好![Mac-10.7.1LionIntel-based]Q:预处理到底干了什么事情?A:预处理,顾名思义,预先做的处理。源代码中...

为“架构”再建个模:如何用代码描述软件架构?

在架构治理平台ArchGuard中,为了实现对架构的治理,我们需要代码+模型描述所要处理的内容和数据。所以,在ArchGuard中,我们有了代码的模型、依赖的模型、变更的模型等,剩下的两个...

深度解析:Google Gemma 3n —— 移动优先的轻量多模态大模型

2025年6月,Google正式发布了Gemma3n,这是一款能够在2GB内存环境下运行的轻量级多模态大模型。它延续了Gemma家族的开源基因,同时在架构设计上大幅优化,目标是让...

比分网开发技术栈与功能详解_比分网有哪些

一、核心功能模块一个基本的比分网通常包含以下模块:首页/总览实时比分看板:滚动展示所有正在进行的比赛,包含比分、比赛时间、红黄牌等关键信息。热门赛事/焦点战:突出显示重要的、关注度高的比赛。赛事导航...

设计模式之-生成器_一键生成设计

一、【概念定义】——“分步构建复杂对象,隐藏创建细节”生成器模式(BuilderPattern):一种“分步构建型”创建型设计模式,它将一个复杂对象的构建与其表示分离,使得同样的构建过程可以创建...

构建第一个 Kotlin Android 应用_kotlin简介

第一步:安装AndroidStudio(推荐IDE)AndroidStudio是官方推荐的Android开发集成开发环境(IDE),内置对Kotlin的完整支持。1.下载And...