news 2026/5/11 9:34:40

Python基础知识-数据结构篇

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python基础知识-数据结构篇

Python 提供了丰富且灵活的内置数据结构,用于高效地组织、存储和操作数据。这些数据结构可分为**可变(mutable)不可变(immutable)**两大类,并根据其特性适用于不同场景。

以下是 Python 中最核心的6 种内置数据结构的详细介绍:


1.列表(List)—— 可变、有序、允许重复

特点:

  • 用方括号[]定义
  • 元素有序(有索引,从 0 开始)
  • 允许存储不同类型的数据(如整数、字符串、对象等)
  • 可变:支持增删改操作
  • 允许重复元素

常见操作:

lst=[1,'hello',3.14,True]lst.append('new')# 添加元素lst[0]=100# 修改lst.insert(1,'x')# 在位置1插入lst.pop()# 删除并返回最后一个元素lst.remove('hello')# 删除第一个匹配项len(lst)# 长度

适用场景:

  • 需要动态修改的数据集合
  • 保持元素插入顺序
  • 频繁按索引访问或遍历

⚠️ 注意:列表在头部插入/删除效率低(O(n)),此时可考虑collections.deque


2.元组(Tuple)—— 不可变、有序、允许重复

特点:

  • 用圆括号()定义(也可省略)
  • 元素有序、可索引
  • 不可变:创建后不能修改内容
  • 允许重复、可包含不同类型

示例:

tup=(1,'a',3.14)# tup[0] = 10 # ❌ 报错!不可变print(tup[1])# 'a'

优势:

  • 比列表更节省内存
  • 可作为字典的键(因不可变)
  • 线程安全(无并发修改风险)

适用场景:

  • 表示固定结构的数据(如坐标(x, y)、RGB 颜色)
  • 函数返回多个值
  • 用作字典键或集合元素

3.字典(Dictionary)—— 可变、无序(Python 3.7+ 保持插入顺序)、键唯一

特点:

  • 用花括号{}定义,格式为{key: value}
  • 键必须是不可变类型(如 str、int、tuple)
  • 值可以是任意类型
  • 键唯一,重复赋值会覆盖旧值
  • Python 3.7 起,字典保持插入顺序

常见操作:

d={'name':'Alice','age':25}d['city']='Beijing'# 添加/修改print(d['name'])# 访问deld['age']# 删除键值对'name'ind# 检查键是否存在d.get('height',0)# 安全取值,不存在返回默认值

适用场景:

  • 映射关系(如配置项、缓存、JSON 数据)
  • 快速查找(平均 O(1) 时间复杂度)

4.集合(Set)—— 可变、无序、元素唯一

特点:

  • 用花括号{}定义(但空集合需用set()
  • 元素无序、不重复
  • 元素必须是不可变类型(如数字、字符串、元组)
  • 支持数学集合运算(并、交、差、对称差)

示例:

s={1,2,3,3}# 自动去重 → {1, 2, 3}s.add(4)s.remove(1)s.discard(10)# 不存在也不报错# 集合运算a={1,2,3}b={3,4,5}print(a|b)# 并集 → {1,2,3,4,5}print(a&b)# 交集 → {3}print(a-b)# 差集 → {1,2}

适用场景:

  • 去重(如list(set(my_list))
  • 成员快速检测(x in my_set比列表快得多)
  • 数学集合操作

💡 不可变集合:frozenset—— 可作为字典键或嵌套在其他集合中


5.字符串(String)—— 不可变、有序、字符序列

特点:

  • 用单引号' '或双引号" "定义
  • 不可变:任何“修改”操作都会生成新字符串
  • 支持索引、切片、遍历
  • 是 Unicode 字符序列(Python 3 默认)

常见操作:

s="Hello"s[0]# 'H's.upper()# 'HELLO'(返回新字符串)'lo'ins# Trues.split()# 分割''.join(['a','b'])# 拼接

适用场景:

  • 文本处理、文件路径、用户输入等

6.其他重要数据结构(来自标准库)

虽然不是“内置”关键字类型,但 Python 标准库提供了更专业的数据结构:

结构所在模块特点
dequecollections双端队列,两端高效插入/删除(O(1))
Countercollections计数器,统计元素出现次数
defaultdictcollections带默认值的字典,避免 KeyError
namedtuplecollections带字段名的元组,可读性更强
OrderedDictcollections显式保持插入顺序(Python 3.7+ 普通 dict 已具备)
heapqheapq最小堆实现,用于优先队列
arrayarray存储同类型基本数据,比列表更省内存

示例:Counter

fromcollectionsimportCounter cnt=Counter(['a','b','a','c'])print(cnt)# Counter({'a': 2, 'b': 1, 'c': 1})

对比总结表

数据结构可变?有序?允许重复?典型用途
list通用序列,动态数组
tuple固定结构,函数返回值
dict✅(3.7+)键❌ / 值✅键值映射,快速查找
set去重,成员检测,集合运算
str文本处理
frozenset不可变集合,可用作键

选择建议

  • 需要顺序 + 可修改list
  • 数据固定不变tuple
  • 需要键值对应dict
  • 只关心存在与否/去重set
  • 处理文本str
  • 高性能队列 →collections.deque
  • 统计频次 →collections.Counter

掌握这些数据结构及其特性,是写出高效、清晰 Python 代码的基础。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/10 17:15:02

Langchain-Chatchat如何评估不同Embedding模型效果?

Langchain-Chatchat 如何科学评估不同 Embedding 模型效果? 在企业智能化浪潮中,一个反复出现的挑战是:如何让大模型真正“读懂”自家文档?通用语言模型虽然能写诗作曲,却对公司的报销流程、产品手册一无所知。于是&am…

作者头像 李华
网站建设 2026/4/27 21:17:25

【2026年精选毕业设计:基于多模态日程感知的校园智能待办助手小程序(含论文+源码+PPT+开题报告+任务书+答辩讲解)】

2026年精选毕业设计:基于多模态日程感知的校园智能待办助手小程序(含论文源码PPT开题报告任务书答辩讲解) 发布时间:2025-12-19 19:00 分类:毕业设计 / 微信小程序 / 人工智能 / 教育信息化 标签:微信小程序…

作者头像 李华
网站建设 2026/5/10 3:58:10

25、三维量子力学中的角动量与中心势问题解析

三维量子力学中的角动量与中心势问题解析 1. 三维量子力学中的角动量回顾 初涉量子力学的学习者,需明确量子物理里的角动量与经典力学中的定义有别。量子物理中的角动量算符(可观测量),其各分量的对易子需满足特定准则,除轨道角动量外,多数角动量算符并无经典对应。 1…

作者头像 李华
网站建设 2026/5/11 13:01:48

26、三维中心势问题的量子力学分析

三维中心势问题的量子力学分析 1. 波函数在极端 r 值下的行为 在量子力学中,了解波函数在 r 的极端值下的行为是很有帮助的。这里主要关注束缚态,但在原点附近,这种限制并非必要。 1.1 r 趋近于 0 时的波函数 通过考察径向的定态薛定谔方程(TISE),当 U(r) 对 r 的依赖…

作者头像 李华
网站建设 2026/5/11 23:38:35

28、量子物理中的势能与能级研究

量子物理中的势能与能级研究 1. 自旋 - 轨道耦合与简并能级 在量子物理中,简并的各向同性振子能级会受到自旋 - 轨道耦合的影响。例如,到 $n = 3$ 的简并能级会因自旋 - 轨道耦合而分裂,这种分裂机制有助于解释原子核的壳层结构。自旋 - 轨道耦合的“强”表现为其引起的能…

作者头像 李华
网站建设 2026/5/11 8:51:52

33、自旋 - 轨道耦合、原子核壳层模型与氦原子的量子态分析

自旋 - 轨道耦合、原子核壳层模型与氦原子的量子态分析 1. 狄拉克方程与氢原子能量 狄拉克方程具有相对论属性,必然包含相对论效应。求解狄拉克方程得到的氢原子量子化能量中,应包含源于电子自旋的项。狄拉克方程能量本征值的精确表达式为: [E_{nj} = m_ec^2 \left(1 + \…

作者头像 李华