Python语法详解module3(组合数据类型列表、元组、字典、集合详细用法)

在这里插入图片描述

目录

  • 一、列表
    • 列表的创建
    • 多维列表
    • 列表的访问和修改
    • 列表的添加和删除
    • 列表的遍历
      • 使用 for 循环遍历
      • 使用 while 循环遍历
      • 同时遍历索引和元素
      • 列表推导式
    • 常用的列表函数
      • len()
      • sort()
      • reverse()
      • index()
      • count()
      • extend()
      • clear()
  • 二、元组
    • 创建元组
    • 访问元组元素
    • 元组的不可变性
    • 元组的优点
    • 元组的应用场景
  • 三、字典
    • 创建字典
    • 访问字典元素
    • 添加或修改元素
    • 删除元素
    • 字典的遍历
    • 字典的常用方法
  • 四、集合
    • 创建集合
    • 集合的特点
    • 访问集合元素
    • 修改集合
    • 集合的常用操作
    • 集合的应用场景

一、列表

  • 列表是 Python 中最常用的数据结构之一,它是一个有序的集合,可以包含任何数据类型的元素,如整数、浮点数、字符串等。
  • 列表使用方括号 [ ] 表示,各元素之间用逗号 , 分隔。
  • 列表中的元素可以通过索引访问,并且列表是可变的,即可以修改、添加或删除其中的元素。

列表的创建

在Python中,列表可以通过以下方式来创建:

# 创建一个空列表
my_list = []

# 创建一个带有初始元素的列表
my_list = [1, 2, 3, 4, 5]

my_list = [1, 'a', 2.3]   # 一个包含整数、字符串和浮点数的列表

# 创建一个包含其他列表的列表(嵌套列表)
nested_list = [[1, 2], [3, 4], [5, 6]]

多维列表

  • 多维列表通常被称为嵌套列表,它是列表中包含其他列表的列表。
  • 这种嵌套结构使得 Python 的列表能够灵活地表示多维数据结构,例如矩阵、数组等。
# 创建一个二维列表(3x3矩阵)
matrix = [[1, 2, 3],
          [4, 5, 6],
          [7, 8, 9]]

# 访问列表元素
print(matrix[0][0])  # 输出:1
print(matrix[1][2])  # 输出:6
print(matrix[2][1])  # 输出:8

# 修改列表元素
matrix[1][1] = 10
print(matrix[1][1])  # 输出:10

# 添加新的列表
new_row = [11, 12, 13]
matrix.append(new_row)
print(matrix)  # 输出:[[1, 2, 3], [4, 10, 6], [7, 8, 9], [11, 12, 13]]

列表的访问和修改

  • 访问列表中的元素可以使用索引,索引从0开始,可以使用负数索引从末尾开始计数。
my_list = [1, 2, 3, 4, 5]

# 访问列表元素
print(my_list[0])  # 输出: 1
print(my_list[-1])  # 输出: 5

# 修改列表元素
my_list[0] = 10
print(my_list)  # 输出: [10, 2, 3, 4, 5]

列表的添加和删除

  • 向列表中添加元素可以使用 append() 方法,删除元素可以使用 remove() 方法或 pop() 方法。
    在这里插入图片描述

在这里插入图片描述

my_list = [1, 2, 3, 4, 5]

# 添加元素
my_list.append(6)
print(my_list)  # 输出: [1, 2, 3, 4, 5, 6]

# 删除元素
my_list.remove(3)  # 删除值为3的元素
print(my_list)  # 输出: [1, 2, 4, 5, 6]

popped_element = my_list.pop(2)  # 删除索引为2的元素
print(popped_element)  # 输出: 4
print(my_list)  # 输出: [1, 2, 5, 6]

列表的遍历

使用 for 循环遍历

my_list = [1, 2, 3, 4, 5]
for item in my_list:
    print(item)

使用 while 循环遍历

my_list = [1, 2, 3, 4, 5]
index = 0
while index < len(my_list):
    print(my_list[index])
    index += 1

同时遍历索引和元素

有时候可能需要同时访问元素和其索引,可以使用 enumerate() 函数来实现:

my_list = [1, 2, 3, 4, 5]
for index, item in enumerate(my_list):
    print(index, item)

列表推导式

列表推导式是一种更为简洁的方式来遍历列表和对列表进行操作:

my_list = [1, 2, 3, 4, 5]
# 将每个元素加倍
doubled_list = [item * 2 for item in my_list]
print(doubled_list)

常用的列表函数

len()

len() 函数返回列表中元素的个数。

my_list = [1, 2, 3, 4, 5]
print(len(my_list))  # 输出: 5

sort()

sort() 方法用于对列表进行排序。

my_list = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5]
my_list.sort()
print(my_list)  # 输出: [1, 1, 2, 3, 3, 4, 5, 5, 5, 6, 9]

在这里插入图片描述

reverse()

reverse() 方法用于颠倒列表中的元素顺序。

my_list = [1, 2, 3, 4, 5]
my_list.reverse()
print(my_list)  # 输出: [5, 4, 3, 2, 1]

index()

index() 方法用于返回指定元素的索引。

my_list = ['apple', 'banana', 'cherry', 'apple']
print(my_list.index('banana'))  # 输出: 1

count()

  • count() 方法用于返回指定元素在列表中出现的次数。
my_list = [1, 2, 2, 3, 3, 3]
print(my_list.count(3))  # 输出: 3

extend()

  • extend() 方法用于将另一个列表的元素添加到当前列表。
list1 = [1, 2, 3]
list2 = [4, 5, 6]
list1.extend(list2)
print(list1)  # 输出: [1, 2, 3, 4, 5, 6]

clear()

  • clear() 方法用于清空列表中的所有元素。
my_list = [1, 2, 3, 4, 5]
my_list.clear()
print(my_list)  # 输出: []

在这里插入图片描述


二、元组

  • 元组(tuple)类似于列表,但是元组是不可变的,意味着一旦创建,其内容就不能被修改、添加或删除。
  • 元组用圆括号 () 来表示。

创建元组

可以使用逗号 , 将多个元素组合在一起来创建元组,也可以使用圆括号 () 将元素括起来来创建元组。

# 使用逗号
my_tuple = 1, 2, 3, 4, 5
print(my_tuple)  # 输出: (1, 2, 3, 4, 5)

# 使用圆括号
my_tuple = (1, 2, 3, 4, 5)
print(my_tuple)  # 输出: (1, 2, 3, 4, 5)

在这里插入图片描述

访问元组元素

可以使用索引来访问元组中的元素,索引从0开始。

my_tuple = (1, 2, 3, 4, 5)
print(my_tuple[0])  # 输出: 1
print(my_tuple[2])  # 输出: 3

元组的不可变性

元组是不可变的,这意味着你不能修改元组中的元素,也不能向元组中添加或删除元素。

my_tuple = (1, 2, 3)
my_tuple[0] = 5  # 会抛出 TypeError: 'tuple' object does not support item assignment

元组的优点

  • 不可变性(Immutable):元组的内容在创建后不能被修改,这样可以保证数据的安全性和稳定性。
  • 性能:由于元组的不可变性,Python 可以对元组进行一些优化,使其在某些情况下比列表更快。

元组的应用场景

  • 函数返回值:函数可以返回多个值,这些值可以使用元组来返回。
  • 不可变的键:元组可以作为字典的键,而列表不能,因为字典的键必须是不可变的。
# 函数返回值
def get_point():
    return 10, 20

x, y = get_point()
print(x, y)  # 输出: 10 20

# 不可变的键
my_dict = {(1, 2): 'value'}
print(my_dict[(1, 2)])  # 输出: value

元组是一种简单但强大的数据结构,可以用于安全地存储和传递数据,特别是在需要不可变性和性能方面。


三、字典

  • 字典(dictionary)是一个无序、可变、以键值对形式存储数据的集合。
  • 每个键值对都由一个键和一个与之相关联的值组成。
  • 在字典中,键必须是唯一的,而值可以是任意类型的对象。
  • 字典用花括号 {} 来表示,每个键值对之间使用逗号 , 分隔。

创建字典

# 创建空字典
my_dict = {}

# 创建带有初始键值对的字典
my_dict = {'name': 'yushifu', 'age': 23, 'city': 'Beijing'}

访问字典元素

可以通过键来访问字典中的值。

my_dict = {'name': 'yushifu', 'age': 25, 'city': 'Beijing'}
print(my_dict['name'])  # 输出: yushifu
print(my_dict['age'])   # 输出: 23

添加或修改元素

可以通过给指定的键赋值的方式向字典中添加新的键值对,如果该键已经存在,则会修改对应的值。

my_dict = {'name': 'yushifu', 'age': 23, 'city': 'Beijing'}
my_dict['gender'] = 'male'  # 添加新的键值对
my_dict['age'] = 26  # 修改已有键的值

删除元素

可以使用 del 关键字来删除字典中的键值对,也可以使用 pop() 方法来删除指定键并返回其对应的值。

my_dict = {'name': 'yushifu', 'age': 23, 'city': 'Beijing'}
del my_dict['age']  # 删除键为 'age' 的键值对
age = my_dict.pop('age')  # 删除键为 'age' 的键值对,并返回值

字典的遍历

可以通过循环来遍历字典中的键值对。

my_dict = {'name': 'yushifu', 'age': 23, 'city': 'Beijing'}
for key, value in my_dict.items():
    print(key, value)

字典的常用方法

  • keys():返回字典中所有的键。
  • values():返回字典中所有的值。
  • items():返回字典中所有的键值对。
my_dict = {'name': 'yushifu', 'age': 23, 'city': 'Beijing'}
print(my_dict.keys())   # 输出: dict_keys(['name', 'age', 'city'])
print(my_dict.values())  # 输出: dict_values(['yushifu', 23, 'Beijing'])
print(my_dict.items())   # 输出: dict_items([('name', 'yushifu'), ('age', 23), ('city', 'Beijing')])

字典适合用于存储和操作具有键值对关系的数据。


四、集合

  • Python中的集合(set)是一种无序且不重复的元素集,类似数学中的集合概念。
  • 集合可以用于去重、判断成员关系等操作。
  • 集合使用花括号 {} 来表示,元素之间使用逗号 , 分隔。

创建集合

  • 可以使用花括号 {} 来创建集合。
  • 也可以使用 set() 函数来创建一个空集合或从其他可迭代对象中创建集合。
# 创建空集合
my_set = set()

# 从列表中创建集合
my_set = set([1, 2, 3, 4, 5])

# 直接创建集合
my_set = {1, 2, 3, 4, 5}

集合的特点

  • 无序性:集合中的元素没有顺序,不能通过索引访问。
  • 唯一性:集合中的元素是唯一的,不存在重复元素。

访问集合元素

由于集合是无序的,不能通过索引来访问元素。可以使用循环或者转换为列表来访问集合中的元素。

my_set = {1, 2, 3, 4, 5}
for item in my_set:
    print(item)

# 将集合转换为列表
my_list = list(my_set)
print(my_list)  # 输出: [1, 2, 3, 4, 5]

修改集合

由于集合的元素是不可变的,不能直接修改集合中的元素。但是可以添加新的元素或者删除已有的元素。

my_set = {1, 2, 3}
my_set.add(4)  # 添加元素
my_set.remove(2)  # 移除元素

集合的常用操作

  • 并集、交集、差集:可以使用集合操作符 |&- 来执行集合的并集、交集和差集操作。
  • 成员关系判断:可以使用 innot in 来判断元素是否在集合中。
set1 = {1, 2, 3, 4}
set2 = {3, 4, 5, 6}

# 并集
union_set = set1 | set2  # 输出: {1, 2, 3, 4, 5, 6}
# 交集
intersection_set = set1 & set2  # 输出: {3, 4}
# 差集
difference_set = set1 - set2  # 输出: {1, 2}
# 成员关系判断
print(2 in set1)  # 输出: True
print(5 not in set1)  # 输出: True

集合的应用场景

  • 去重:通过集合可以快速实现对列表等可迭代对象的去重操作。
  • 成员关系判断:可以高效地判断一个元素是否包含在集合中。
  • 集合运算:可以方便地进行集合的并集、交集、差集等操作。

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Linux】(三)—— 文件管理和软件安装

文件管理 Linux的文件管理是系统管理中的核心部分&#xff0c;它涉及到如何组织、访问、修改和保护文件及目录结构。 目录 文件管理基本概念常用命令查看和切换目录创建文件和目录删除文件和目录文件拷贝移动和重命名文件文件查看cat文件查看more查找文件查找文本 数据流和管道…

软件测试报告实际案例模板(项目测试文档doc原件)

软件测试报告在软件开发过程中起着至关重要的作用&#xff0c;主要有以下几个主要原因&#xff1a; 1、确保软件质量 2、提供决策支持 3、记录测试过程和结果 4、促进沟通和协作 5、符合标准和法规要求 6、改进测试流程和策略 7、降低风险 软件开发全套资料获取进主页或者本文末…

SEACells:元细胞分析

元细胞是从单细胞测序数据中衍生的细胞分组&#xff0c;代表高度精细的不同细胞状态。在这里&#xff0c;作者介绍了单细胞细胞状态聚集 (SEACells)&#xff0c;这是一种用于识别元细胞的算法&#xff0c;它克服了单细胞数据的稀疏性&#xff0c;同时保留了传统细胞聚类所掩盖的…

LW-DETR:实时目标检测的Transformer, Apache-2.0 开源可商用,实验超 YOLOv8

LW-DETR&#xff1a;实时目标检测的Transformer&#xff0c; Apache-2.0 开源可商用&#xff0c;实验超 YOLOv8 LW-DETR 架构实例化高效训练高效推理 目的与解法拆解ViT编码器和DETR解码器多级特征图聚合变形交叉注意力窗口注意力和全局注意力 论文&#xff1a;https://arxiv.o…

QT系列教程(9) 主窗口学习

简介 任何界面应用都有一个主窗口&#xff0c;今天我们谈谈主窗口相关知识。一个主窗口包括菜单栏&#xff0c;工具栏&#xff0c;状态栏&#xff0c;以及中心区域等部分。我们先从菜单栏说起 菜单栏 我们创建一个主窗口应用程序, 在ui文件里的菜单栏里有“在这里输入”的一个…

AI大底座核心平台:百度百舸AI异构计算平台(AI IaaS)与AI中台(AI PaaS)

AI大底座正是整合了以上端到端全要素技术能力&#xff0c;将基础架构IaaS与应用平台PaaS能力深度融合&#xff0c;面向企业和产业AI生 产与应用的全生命周期提供完整解决方案。 百舸AI异构计算平台是AI IaaS层的核心平台&#xff0c;包括AI计算、AI存储、AI加速、AI容器四层套件…

算法人生(19): 从“LangChain的六大组件”看“个人职业规划”

我们今天要说说和大模型有着密切关系的Langchain &#xff0c;它提供了一个平台&#xff0c;让开发者可以更加轻松地训练、部署和管理这些大模型。具体来说&#xff0c;Langchain 可以通过提供高性能的计算资源、灵活的模型管理和部署选项、以及丰富的监控和调试功能&#xff0…

「动态规划」如何求下降路径最小和?

931. 下降路径最小和https://leetcode.cn/problems/minimum-falling-path-sum/description/ 给你一个n x n的方形整数数组matrix&#xff0c;请你找出并返回通过matrix的下降路径的最小和。下降路径可以从第一行中的任何元素开始&#xff0c;并从每一行中选择一个元素。在下一…

CentOS 环境下 PostgreSQL 在线安装和源码安装详解

1、内容概述 昨天给大家简单的介绍了一下 PostgreSQL,并且在Windows系统上通过图形化界面的方式搭建好了环境&#xff0c;今天我们就来学习一下如何在Linux 系统上搭建 PostgreSQL环境&#xff0c;我会给大家介绍在线安装、离线源码安装以及Docker 安装三种方式。 2、在线安装…

umijs 服务端渲染(SSR) 指南

umijs 服务端渲染&#xff08;SSR&#xff09; 指南 Umi 是什么&#xff1f; Umi&#xff0c;中文可发音为乌米&#xff0c;是可扩展的企业级前端应用框架。Umi 以路由为基础的&#xff0c;同时支持配置式路由和约定式路由&#xff0c;保证路由的功能完备&#xff0c;并以此进…

枚举(enum)+联合体(union)

枚举联合 一.枚举类型1.枚举类型的声明2.枚举类型的优点3.枚举类型的使用 二.联合体1.联合体类型的声明2.联合体的特点3.相同成员的结构体和联合体对比4.联合体大小的计算5.联合体的练习&#xff08;判断大小端&#xff09;6.联合体节省空间例题 一.枚举类型 1.枚举类型的声明…

安全U盘和普通U盘有什么区别?

安全U盘&#xff08;也称为加密U盘或安全闪存驱动器&#xff09;与普通U盘肯定是有一些区别的&#xff0c;从字面意思上来看&#xff0c;就能看出&#xff0c;安全U盘是能够保护文件数据安全性的&#xff0c;普通U盘没这一些功能的&#xff0c;可随意拷贝文件&#xff0c;不防盗…

Hadoop3:MapReduce源码解读之Mapper阶段的TextInputFormat切片机制(3)

Job那块的断点代码截图省略&#xff0c;直接进入切片逻辑 参考&#xff1a;Hadoop3&#xff1a;MapReduce源码解读之Mapper阶段的Job任务提交流程&#xff08;1&#xff09; 5、TextInputFormat源码解析 类的继承关系 它的内容比较少 重写了两个父类的方法 这里关心一下泛型…

《开源模型食用指南》基于Linux环境快速部署开源模型,更适合中国宝宝的部署教程

今天给大家推荐一个非常适合中国宝宝学习的专属大模型教程&#xff0c;也就是它《开源模型食用指南》&#xff01; 当前百模大战正值火热&#xff0c;开源LLM层出不穷。 如今国内外已经涌现了众多优秀开源LLM&#xff0c;国外如LLaMA、Alpaca&#xff0c;国内如ChatGLM、BaiCh…

【Unity Shader入门精要 第13章】使用深度和法线纹理(一)

1. 原理 深度纹理的本质是一张RenderTexture&#xff0c;只不过其中记录的不是颜色值&#xff0c;而是一个深度值 这些深度值来自于顶点在空间变换后得到的归一化设备坐标&#xff08;NDC&#xff09;的Z值 由于NDC坐标的分量取值范围在[-1, 1]之间&#xff0c;要使颜色值能…

欧盟EDPS发布首份生成式人工智能与数据安全指南解读

6月3日&#xff0c;欧洲数据保护监督机构&#xff08;EDPS&#xff09;在其官网上发布了题为《生成式人工智能与EUDPR》的指南&#xff08;注&#xff1a;EUDPR指的是《欧盟2018/1725号条例》&#xff09;&#xff0c;这是首份适用于欧盟机构的人工智能与数据安全指南。 01 指南…

STM32 SPI驱动读取LSM6DSRTR

提示&#xff1a;通过SPI驱动读取传感器数据 文章目录 前言一、LSM6DSRTR二、配置步骤1.配置SPI2.引入 LSM驱动库3.结果 总结 前言 制作一个倾角传感器&#xff0c;通过SPI读取LSM6DSRTR的加速度数据转换为角度&#xff0c;不用IIC的原因是考虑IIC通讯的协议过于繁琐&#xff…

c# iText使用

引入包 用nuget安装itext和itext.bouncy-castle-adapter包&#xff1a; 创建pdf string path "a.pdf"; PdfWriter writer new PdfWriter(path); PdfDocument pdfDoc new PdfDocument(writer); var docnew Document(pdfDoc); Paragraph p new Paragraph(&quo…

Java装饰器模式,装饰器模式通常通过创建一个接口和一个或多个实现了该接口的类来开始,然后创建装饰器类,这些类也实现了相同的接口

1、定义一个接口Component public interface Component { void operation(); }2、创建一个实现了Component接口的简单类SimpleComponent public class SimpleComponent implements Component { Override public void operation() { System.out.println("SimpleCom…

正大国际期货:什么是主力合约?

一个期货品种&#xff0c;在同一时间段&#xff0c;会上市多个月份的合约&#xff0c; 由于主力合约交易量大&#xff0c;流动性高&#xff0c;一般建议新手交易主力合约。 主力合约通常指交易集中&#xff0c;流动性好的合约 &#xff0c;即在一段时间内交易量和持仓量最大的…