白骑士的Python教学基础篇 1.5 数据结构
系列目录
上一篇:白骑士的Python教学基础篇 1.4 函数与模块
数据结构是编程语言中用于存储和组织数据的基本构件。在Python中,常见的数据结构包括列表(List)、元组(Tuple)、字典(Dictionary)和集合(Set)。每种数据结构都有其独特的特性和用途。理解这些数据结构及其用法,对于编写高效且易于维护的Python代码至关重要。
列表(List)
列表是Python中最常用的数据结构之一。它是一个有序的集合,可以包含任意类型的元素,包括数字、字符串、其他列表等。列表是可变的,这意味着我们可以修改列表中的元素。
创建列表
# 创建一个空列表
empty_list = []# 创建一个包含元素的列表
fruits = ["apple", "banana", "cherry"]
访问列表元素
# 通过索引访问元素
print(fruits[0]) # 输出: apple# 通过负索引访问元素
print(fruits[-1]) # 输出: cherry
修改列表元素
# 修改列表中的元素
fruits[1] = "blueberry"
print(fruits) # 输出: ['apple', 'blueberry', 'cherry']
添加和删除元素
# 使用append()方法添加元素
fruits.append("date")
print(fruits) # 输出: ['apple', 'blueberry', 'cherry', 'date']# 使用remove()方法删除元素
fruits.remove("blueberry")
print(fruits) # 输出: ['apple', 'cherry', 'date']# 使用pop()方法删除并返回最后一个元素
last_fruit = fruits.pop()
print(last_fruit) # 输出: date
print(fruits) # 输出: ['apple', 'cherry']
列表切片
# 列表切片可以返回一个新的列表
print(fruits[0:2]) # 输出: ['apple', 'cherry']
列表推导式
# 使用列表推导式创建列表
squares = [x**2 for x in range(10)]
print(squares) # 输出: [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
元组(Tuple)
元组与列表类似,但元组是不可变的。这意味着一旦创建,元组中的元素就不能修改。这使得元组适用于那些不希望被修改的数据集合。
创建元组
# 创建一个空元组
empty_tuple = ()# 创建一个包含元素的元组
numbers = (1, 2, 3)
访问元组元素
# 通过索引访问元素
print(numbers[1]) # 输出: 2# 通过负索引访问元素
print(numbers[-1]) # 输出: 3
不可变特性
# 尝试修改元组中的元素会引发错误
# numbers[1] = 4 # 这行代码会引发TypeError
元组解包
# 元组解包
a, b, c = numbers
print(a, b, c) # 输出: 1 2 3
单元素元组
# 创建一个包含单个元素的元组时需要在元素后加一个逗号
single_element_tuple = (4,)
print(single_element_tuple) # 输出: (4,)
字典(Dictionary)
字典是Python中另一种重要的数据结构。它是一个无序的键值对集合,每个键必须是唯一的,可以是任意不可变数据类型,而值可以是任意数据类型。
创建字典
# 创建一个空字典
empty_dict = {}# 创建一个包含键值对的字典
person = {"name": "Alice", "age": 25, "city": "New York"}
访问字典元素
# 通过键访问值
print(person["name"]) # 输出: Alice# 使用get()方法访问值,如果键不存在则返回None
print(person.get("name")) # 输出: Alice
print(person.get("address")) # 输出: None
修改字典元素
# 修改字典中的值
person["age"] = 26
print(person) # 输出: {'name': 'Alice', 'age': 26, 'city': 'New York'}# 添加新键值对
person["email"] = "alice@example.com"
print(person) # 输出: {'name': 'Alice', 'age': 26, 'city': 'New York', 'email': 'alice@example.com'}
删除字典元素
# 使用del关键字删除键值对
del person["city"]
print(person) # 输出: {'name': 'Alice', 'age': 26, 'email': 'alice@example.com'}# 使用pop()方法删除并返回指定键的值
email = person.pop("email")
print(email) # 输出: alice@example.com
print(person) # 输出: {'name': 'Alice', 'age': 26}
遍历字典
# 遍历字典的键值对
for key, value in person.items():print(f"{key}: {value}")# 输出:
# name: Alice
# age: 26
集合(Set)
集合是一个无序的不重复元素集合。集合主要用于成员关系测试和删除重复元素。集合支持数学上的集合操作,如并集、交集、差集等。
创建集合
# 创建一个空集合
empty_set = set()# 创建一个包含元素的集合
fruits_set = {"apple", "banana", "cherry"}
访问集合元素
# 不能通过索引访问集合中的元素,但可以通过迭代访问
for fruit in fruits_set:print(fruit)# 输出的顺序是无序的
添加和删除元素
# 添加元素
fruits_set.add("date")
print(fruits_set) # 输出: {'date', 'apple', 'cherry', 'banana'}# 删除元素
fruits_set.remove("banana")
print(fruits_set) # 输出: {'date', 'apple', 'cherry'}# 使用discard()方法删除元素,如果元素不存在也不会引发错误
fruits_set.discard("banana")
集合操作
# 创建两个集合
set_a = {1, 2, 3, 4}
set_b = {3, 4, 5, 6}# 并集
union_set = set_a | set_b
print(union_set) # 输出: {1, 2, 3, 4, 5, 6}# 交集
intersection_set = set_a & set_b
print(intersection_set) # 输出: {3, 4}# 差集
difference_set = set_a - set_b
print(difference_set) # 输出: {1, 2}# 对称差集
symmetric_difference_set = set_a ^ set_b
print(symmetric_difference_set) # 输出: {1, 2, 5, 6}
集合推导式
# 使用集合推导式创建集合
squares_set = {x**2 for x in range(10)}
print(squares_set) # 输出: {0, 1, 4, 9, 16, 25, 36, 49, 64, 81}
总结
Python提供了丰富的数据结构来处理不同类型的数据。列表(List)适用于有序且可变的集合;元组(Tuple)用于不可变的数据集合;字典(Dictionary)提供了键值对的映射;集合(Set)则用于处理无序且不重复的元素集合。通过理解和使用这些数据结构,可以编写出更高效、清晰且易维护的Python代码。无论是进行简单的数据存储,还是复杂的数据处理操作,这些数据结构都是不可或缺的工具。
下一篇:白骑士的Python教学进阶篇 2.1 面向对象编程(OOP)
相关文章:
白骑士的Python教学基础篇 1.5 数据结构
系列目录 上一篇:白骑士的Python教学基础篇 1.4 函数与模块 数据结构是编程语言中用于存储和组织数据的基本构件。在Python中,常见的数据结构包括列表(List)、元组(Tuple)、字典(…...
Go 常用文件操作
查找文件/目录 os.Stat(String)组合路径 dir, _ : homedir.Dir() filename : args[0] path : filepath.Join(dir, filename)homedir.Dir()为home根目录。 filepath.Join 会自动处理分隔符,将目录和文件名组合成文件路径。 检查是否含有后缀.json strings.HasSu…...
大数据、人工智能、云计算、物联网、区块链序言【大数据导论】
各位大佬好 ,这里是阿川的博客,祝您变得更强 个人主页:在线OJ的阿川 大佬的支持和鼓励,将是我成长路上最大的动力 阿川水平有限,如有错误,欢迎大佬指正 本篇序言前 必看 【大数据导论】—大数据序言 这是…...
ComfyUI流程图、文生图、图生图步骤教学!
前言 leetcode , 209. 长度最小的子数组 给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其总和大于等于 target 的长度最小的子数组 [numsl, numsl1, …, numsr-1, numsr] ,并返回其长度。如果不存在符合条件的子数组,返回 0 …...
CSS基础知识学习指南
CSS基础知识学习指南 1. 介绍 CSS(层叠样式表)是用于描述HTML文档的呈现样式的语言。通过CSS,可以控制网页的布局、颜色、字体等各种样式,使得网页更加美观和用户友好。 2. CSS基础语法 CSS由选择器和声明块组成。选择器用于选…...
力扣hot100 -- 贪心算法
👂 ▶ 逍遥叹 - 胡歌&沈以城【Mashup】 (163.com) 👂 庐州月 - 许嵩 - 单曲 - 网易云音乐 2.7 小时,加上写博客,4 道题,😂 -- 希望二刷时,可以 3 小时,8 道题.... 目录 &…...
P2P文件传输协议介绍
P2P文件传输协议是一种基于对等网络(Peer-to-Peer,简称P2P)的文件共享和传输技术。以下是关于P2P文件传输协议的详细介绍: 一、定义与原理 P2P文件传输协议允许网络中的各个节点(即计算机或其他设备)之间…...
Spring Boot集成Spring Mobile快速入门Demo
1.什么是Spring Mobile? Spring Mobile是一个基于Spring Web MVC框架扩展的一个针对不同移动终端的应用开发框架。通过它我们在适配不同终端方面,就不用费劲心思了。 Spring Mobile的主要功能 自动设备检测: Spring Mobile在 server端内置了一个设备解…...
走进开源企业 | 湖南大学OpenHarmony技术实训活动在开鸿智谷顺利举办!
6月24日-6月26日,2024开放原子校源行之湖南大学信息科学与工程学院师生走进开源企业实训交流活动顺利落下帷幕。湖南大学信息科学与工程学院的师生代表团一行90人参与了湖南开鸿智谷数字产业有限公司(以下简称“开鸿智谷”)与母公司拓维信息系…...
TCP单进程循环服务器程序与单进程客户端程序
实验目的 理解并掌握以下内容: 网络进程标识(即套接字地址)在Linux中的数据结构与地址转换函数。网络字节序与主机字节序的定义、转换以及相关函数在网络编程中的应用。数据结构内存对齐的基本规则,以及基于数据结构构建PDU的基本方法。TCP单进程循环服务器与单进程客户端的…...
QT+winodow 代码适配调试总结(二)
已经好多年了, linux环境下不同版本的QT程序开发和部署,突然需要适配window环境程序调试,一堆大坑,还真是一个艰巨的任务,可是kpi下的任务计划,开始吧!! 1、首先我们自定义的动态库…...
百家讲坛 | 裴伟伟:企业中安全团队应当如何反馈漏洞
作者简介:裴伟伟,洞源实验室创始人,国家网安基地网络安全行业专家,网安加社区特聘专家,持有CISSP、PMP证书,曾在HITCON、可信云大会、开源产业大会等安全论坛发表演讲。曾任国内某安全实验室负责人、某互金…...
巧用Fiddler中的Comments提升接口测试效率
有没有同学在使用Fiddler时跟我遇到了同样的问题,就是想给某个抓包的请求进行注释!!!但是奇怪的是,根本没有Comments相关信息呀? 设置Comments 设置Comments非常容易,选中一个请求,…...
停车场车牌识别计费系统,用Python如何实现?
关注星标,每天学习Python新技能 前段时间练习过的一个小项目,今天再看看,记录一下~ 项目结构 说明: datefile文件夹:保存车辆信息表的xlsx文件 file文件夹:保存图片文件夹。ic_launcher.jpg是窗体的右上角…...
Linux内核——Linux内核体系模式(二)
1 Linux系统的中断机制 Linux内核将中断分为两类:硬件中断和软件中断(异常)。每个中断是由0-255之间的一个数字进行标识。 中断int0-int31(0x00-0x1f)作为异常int32-int255由用户自己设定 int32-int47对应与8259A中断…...
Spring MVC的高级功能——异常处理(一)简单异常处理器
一、HandlerExceptionResolver接口 如果希望对Spring MVC中所有异常进行统一处理,可以使用Spring MVC提供的异常处理器HandlerExceptionResolver接口。Spring MVC内部提供了HandlerExceptionResolver的实现类SimpleMappingExceptionResolver。它实现了简单的异常处理…...
【面试干货】Static关键字的用法详解
【面试干货】Static关键字的用法详解 1、Static修饰内部类2、Static修饰方法3、Static修饰变量4、Static修饰代码块5、总结 💖The Begin💖点点关注,收藏不迷路💖 在Java编程语言中,static是一个关键字,它可…...
软件工程实验
实验环境和需求 用户可以对相片进行按类别管理,用户可以设定不同的类别,然后上传照片到相应的类别中,并能进行照片的删除,注释 运行 运行并访问 localhost 8090,图片在数据库中的信息是D:/upgrade 后面的内容 se…...
对于复杂的网页布局,如多列布局和网格布局,CSS 有哪些最佳实践和技巧?
对于复杂的网页布局,如多列布局和网格布局,以下是一些CSS的最佳实践和技巧: 使用Flexbox或CSS Grid布局:Flexbox和CSS Grid是两个强大的CSS布局模型,可用于实现复杂的网页布局。Flexbox适用于单行或单列布局࿰…...
Spring Boot中集成Redis实现缓存功能
Spring Boot中集成Redis实现缓存功能 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天我们将深入探讨如何在Spring Boot应用程序中集成Redis,实现…...
未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?
编辑:陈萍萍的公主一点人工一点智能 未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战,在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…...
Leetcode 3576. Transform Array to All Equal Elements
Leetcode 3576. Transform Array to All Equal Elements 1. 解题思路2. 代码实现 题目链接:3576. Transform Array to All Equal Elements 1. 解题思路 这一题思路上就是分别考察一下是否能将其转化为全1或者全-1数组即可。 至于每一种情况是否可以达到…...
el-switch文字内置
el-switch文字内置 效果 vue <div style"color:#ffffff;font-size:14px;float:left;margin-bottom:5px;margin-right:5px;">自动加载</div> <el-switch v-model"value" active-color"#3E99FB" inactive-color"#DCDFE6"…...
HBuilderX安装(uni-app和小程序开发)
下载HBuilderX 访问官方网站:https://www.dcloud.io/hbuilderx.html 根据您的操作系统选择合适版本: Windows版(推荐下载标准版) Windows系统安装步骤 运行安装程序: 双击下载的.exe安装文件 如果出现安全提示&…...
Psychopy音频的使用
Psychopy音频的使用 本文主要解决以下问题: 指定音频引擎与设备;播放音频文件 本文所使用的环境: Python3.10 numpy2.2.6 psychopy2025.1.1 psychtoolbox3.0.19.14 一、音频配置 Psychopy文档链接为Sound - for audio playback — Psy…...
IoT/HCIP实验-3/LiteOS操作系统内核实验(任务、内存、信号量、CMSIS..)
文章目录 概述HelloWorld 工程C/C配置编译器主配置Makefile脚本烧录器主配置运行结果程序调用栈 任务管理实验实验结果osal 系统适配层osal_task_create 其他实验实验源码内存管理实验互斥锁实验信号量实验 CMISIS接口实验还是得JlINKCMSIS 简介LiteOS->CMSIS任务间消息交互…...
Android Bitmap治理全解析:从加载优化到泄漏防控的全生命周期管理
引言 Bitmap(位图)是Android应用内存占用的“头号杀手”。一张1080P(1920x1080)的图片以ARGB_8888格式加载时,内存占用高达8MB(192010804字节)。据统计,超过60%的应用OOM崩溃与Bitm…...
Map相关知识
数据结构 二叉树 二叉树,顾名思义,每个节点最多有两个“叉”,也就是两个子节点,分别是左子 节点和右子节点。不过,二叉树并不要求每个节点都有两个子节点,有的节点只 有左子节点,有的节点只有…...
2025季度云服务器排行榜
在全球云服务器市场,各厂商的排名和地位并非一成不变,而是由其独特的优势、战略布局和市场适应性共同决定的。以下是根据2025年市场趋势,对主要云服务器厂商在排行榜中占据重要位置的原因和优势进行深度分析: 一、全球“三巨头”…...
网站指纹识别
网站指纹识别 网站的最基本组成:服务器(操作系统)、中间件(web容器)、脚本语言、数据厍 为什么要了解这些?举个例子:发现了一个文件读取漏洞,我们需要读/etc/passwd,如…...
