Python 列表(List)详解
itomcoil 2025-05-27 14:53 19 浏览
列表是 Python 中最基本、最常用的数据结构之一,它是一个有序的、可变的元素集合。
一、列表的基本操作
1. 创建列表
# 空列表
empty_list = []
empty_list = list()
# 包含元素的列表
numbers = [1, 2, 3, 4, 5]
fruits = ['apple', 'banana', 'orange']
mixed = [1, 'hello', 3.14, True]
# 使用list()构造函数
list_from_string = list('Python') # ['P', 'y', 't', 'h', 'o', 'n']
list_from_range = list(range(5)) # [0, 1, 2, 3, 4]
2. 访问列表元素
fruits = ['apple', 'banana', 'orange', 'grape']
# 正索引访问(从0开始)
print(fruits[0]) # 'apple'
print(fruits[2]) # 'orange'
# 负索引访问(从-1开始)
print(fruits[-1]) # 'grape'
print(fruits[-3]) # 'banana'
# 切片操作 [start:end:step]
print(fruits[1:3]) # ['banana', 'orange']
print(fruits[:2]) # ['apple', 'banana']
print(fruits[::2]) # ['apple', 'orange'] (步长为2)
print(fruits[::-1]) # ['grape', 'orange', 'banana', 'apple'] (反转列表)
3. 修改列表
fruits = ['apple', 'banana', 'orange']
# 修改单个元素
fruits[1] = 'pear'
print(fruits) # ['apple', 'pear', 'orange']
# 修改切片
fruits[1:3] = ['grape', 'kiwi']
print(fruits) # ['apple', 'grape', 'kiwi']
# 添加单个元素
fruits.append('melon')
print(fruits) # ['apple', 'grape', 'kiwi', 'melon']
# 添加多个元素
fruits.extend(['peach', 'berry'])
print(fruits) # ['apple', 'grape', 'kiwi', 'melon', 'peach', 'berry']
二、列表常用方法
1. 添加元素
nums = [1, 2, 3]
# append() - 在末尾添加单个元素
nums.append(4) # [1, 2, 3, 4]
# extend() - 添加多个元素(合并列表)
nums.extend([5, 6]) # [1, 2, 3, 4, 5, 6]
# insert() - 在指定位置插入元素
nums.insert(0, 0) # [0, 1, 2, 3, 4, 5, 6]
2. 删除元素
nums = [0, 1, 2, 3, 4, 5, 6, 3]
# remove() - 删除第一个匹配的元素
nums.remove(3) # [0, 1, 2, 4, 5, 6, 3]
# pop() - 删除并返回指定位置的元素(默认最后一个)
last = nums.pop() # 返回3, nums变为[0, 1, 2, 4, 5, 6]
second = nums.pop(1) # 返回1, nums变为[0, 2, 4, 5, 6]
# del语句 - 删除指定位置或切片
del nums[0] # [2, 4, 5, 6]
del nums[1:3] # [2, 6]
# clear() - 清空列表
nums.clear() # []
3. 查找和统计
letters = ['a', 'b', 'c', 'a', 'd', 'a']
# index() - 返回元素的第一个匹配位置
print(letters.index('a')) # 0
print(letters.index('a', 1)) # 3 (从位置1开始查找)
# count() - 统计元素出现次数
print(letters.count('a')) # 3
print(letters.count('x')) # 0
# in操作符 - 检查元素是否存在
print('b' in letters) # True
print('x' in letters) # False
4. 排序和反转
nums = [3, 1, 4, 1, 5, 9, 2]
# sort() - 原地排序
nums.sort() # [1, 1, 2, 3, 4, 5, 9]
nums.sort(reverse=True) # [9, 5, 4, 3, 2, 1, 1]
# sorted() - 返回新排序列表(不改变原列表)
sorted_nums = sorted(nums) # [1, 1, 2, 3, 4, 5, 9]
# reverse() - 原地反转列表
nums.reverse() # [9, 5, 4, 3, 2, 1, 1] -> [1, 1, 2, 3, 4, 5, 9]
三、列表的高级操作
1. 列表推导式
# 创建平方数列表
squares = [x**2 for x in range(10)]
# [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
# 带条件的列表推导式
even_squares = [x**2 for x in range(10) if x % 2 == 0]
# [0, 4, 16, 36, 64]
# 嵌套列表推导式
matrix = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
flattened = [num for row in matrix for num in row]
# [1, 2, 3, 4, 5, 6, 7, 8, 9]
2. 列表复制
original = [1, 2, 3]
# 浅拷贝(三种方式)
copy1 = original.copy()
copy2 = list(original)
copy3 = original[:]
# 深拷贝(用于嵌套列表)
import copy
nested = [[1, 2], [3, 4]]
deep_copy = copy.deepcopy(nested)
3. 列表与字符串转换
# 字符串转列表
s = "hello"
char_list = list(s) # ['h', 'e', 'l', 'l', 'o']
# 列表转字符串
words = ['Python', 'is', 'great']
sentence = ' '.join(words) # "Python is great"
四、列表性能考虑
- 时间复杂度:
- 索引访问:O(1)
- 末尾追加/删除:O(1)
- 中间插入/删除:O(n)
- 查找元素:O(n)
- 选择合适的数据结构:
- 频繁在首部插入/删除:考虑 collections.deque
- 频繁查找/去重:考虑 set 或 dict
- 不可变序列:考虑 tuple
五、实际应用示例
# 示例1:处理成绩数据
grades = [85, 90, 78, 92, 88]
# 计算平均分
average = sum(grades) / len(grades)
# 找出高于平均分的成绩
above_avg = [g for g in grades if g > average]
# 示例2:矩阵转置
matrix = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
transpose = [[row[i] for row in matrix] for i in range(3)]
# [[1, 4, 7], [2, 5, 8], [3, 6, 9]]
列表是 Python 中最灵活的数据结构之一,掌握它的各种操作和特性对于编写高效、清晰的 Python 代码至关重要。
相关推荐
- 最强聚类模型,层次聚类 !!_层次聚类的优缺点
-
哈喽,我是小白~咱们今天聊聊层次聚类,这种聚类方法在后面的使用,也是非常频繁的~首先,聚类很好理解,聚类(Clustering)就是把一堆“东西”自动分组。这些“东西”可以是人、...
- python决策树用于分类和回归问题实际应用案例
-
决策树(DecisionTrees)通过树状结构进行决策,在每个节点上根据特征进行分支。用于分类和回归问题。实际应用案例:预测一个顾客是否会流失。决策树是一种基于树状结构的机器学习算法,用于解决分类...
- Python教程(四十五):推荐系统-个性化推荐算法
-
今日目标o理解推荐系统的基本概念和类型o掌握协同过滤算法(用户和物品)o学会基于内容的推荐方法o了解矩阵分解和深度学习推荐o掌握推荐系统评估和优化技术推荐系统概述推荐系统是信息过滤系统,用于...
- 简单学Python——NumPy库7——排序和去重
-
NumPy数组排序主要用sort方法,sort方法只能将数值按升充排列(可以用[::-1]的切片方式实现降序排序),并且不改变原数组。例如:importnumpyasnpa=np.array(...
- PyTorch实战:TorchVision目标检测模型微调完
-
PyTorch实战:TorchVision目标检测模型微调完整教程一、什么是微调(Finetuning)?微调(Finetuning)是指在已经预训练好的模型基础上,使用自己的数据对模型进行进一步训练...
- C4.5算法解释_简述c4.5算法的基本思想
-
C4.5算法是ID3算法的改进版,它在特征选择上采用了信息增益比来解决ID3算法对取值较多的特征有偏好的问题。C4.5算法也是一种用于决策树构建的算法,它同样基于信息熵的概念。C4.5算法的步骤如下:...
- Python中的数据聚类及可视化分析实践
-
探索如何通过聚类分析揭露糖尿病预测数据集的特征!我们将运用Python的强力工具,深入挖掘数据,以直观的可视化揭示不同特征间的关系。一同探索聚类分析在糖尿病预测中的实践!所有这些可视化都可以通过数据操...
- 用Python来统计大乐透号码的概率分布
-
用Python来统计大乐透号码的概率分布,可以按照以下步骤进行:导入所需的库:使用Python中的numpy库生成数字序列,使用matplotlib库生成概率分布图。读取大乐透历史数据:从网络上找到大...
- python:支持向量机监督学习算法用于二分类和多分类问题示例
-
监督学习-支持向量机(SVM)支持向量机(SupportVectorMachine,简称SVM)是一种常用的监督学习算法,用于解决分类和回归问题。SVM的目标是找到一个最优的超平面,将不同类别的...
- 25个例子学会Pandas Groupby 操作
-
groupby是Pandas在数据分析中最常用的函数之一。它用于根据给定列中的不同值对数据点(即行)进行分组,分组后的数据可以计算生成组的聚合值。如果我们有一个包含汽车品牌和价格信息的数据集,那么可以...
- 数据挖掘流程_数据挖掘流程主要有哪些步骤
-
数据挖掘流程1.了解需求,确认目标说一下几点思考方法:做什么?目的是什么?目标是什么?为什么要做?有什么价值和意义?如何去做?完整解决方案是什么?2.获取数据pandas读取数据pd.read.c...
- 使用Python寻找图像最常见的颜色_python 以图找图
-
如果我们知道图像或对象最常见的是哪种颜色,那么可以解决图像处理中的几个用例,例如在农业领域,我们可能需要确定水果的成熟度。我们可以简单地检查一下水果的颜色是否在预定的范围内,看看它是成熟的,腐烂的,还...
- 财务预算分析全网最佳实践:从每月分析到每天分析
-
原文链接如下:「链接」掌握本文的方法,你就掌握了企业预算精细化分析的能力,全网首发。数据模拟稍微有点问题,不要在意数据细节,先看下最终效果。在编制财务预算或业务预算的过程中,通常预算的所有数据都是按月...
- 常用数据工具去重方法_数据去重公式
-
在数据处理中,去除重复数据是确保数据质量和分析准确性的关键步骤。特别是在处理多列数据时,保留唯一值组合能够有效清理数据集,避免冗余信息对分析结果的干扰。不同的工具和编程语言提供了多种方法来实现多列去重...
- Python教程(四十):PyTorch深度学习-动态计算图
-
今日目标o理解PyTorch的基本概念和动态计算图o掌握PyTorch张量操作和自动求导o学会构建神经网络模型o了解PyTorch的高级特性o掌握模型训练和部署PyTorch概述PyTorc...
- 一周热门
- 最近发表
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)