Python中数组如何操作 Python中数组操作教程

Python中的“数组”主要指list和numpy.ndarray。list是内置的异构序列,支持多种数据类型和动态操作,适合小规模或非数值数据处理;而numpy.ndarray是同质多维数组,基于C实现,内存连续,支持高效数值运算和广播操作,适用于大规模科学计算。两者可通过np.array()和tolist()相互转换,核心区别在于数据类型一致性、性能和功能:list灵活但慢,ndarray高效专用于数值计算。

python中数组如何操作 python中数组操作教程

Python中,我们通常说的“数组”其实有两种主要形式:一种是内置的

list

(列表),它非常灵活,能存放各种类型的数据;另一种是

numpy

库提供的

ndarray

,这才是真正意义上的高性能、同质性数组,尤其适合数值计算和科学计算。理解这两种“数组”的差异和各自的操作方式,是高效编写Python代码的关键。

解决方案

谈到Python中的“数组”操作,我们基本上是在围绕

list

numpy.ndarray

打转。我个人觉得,对于初学者,先从

list

入手是比较自然的,因为它就在那里,开箱即用。而当你的数据量上去,或者需要进行复杂的数值运算时,

numpy

的强大就显现出来了。

1. Python内置列表(

list

)的操作:

list

是最常用的数据结构之一,它允许你存储任意数量、任意类型的数据项。

立即学习“Python免费学习笔记(深入)”;

创建列表:

my_list = [1, 2, 3, 'hello', True]empty_list = []another_list = list(range(5)) # [0, 1, 2, 3, 4]

访问元素: 使用索引(从0开始)和切片。

print(my_list[0])      # 1print(my_list[-1])     # True (访问最后一个元素)print(my_list[1:4])    # [2, 3, 'hello'] (切片操作,不包含结束索引)print(my_list[::2])    # [1, 3, True] (步长为2)

修改元素:

my_list[0] = 100print(my_list)         # [100, 2, 3, 'hello', True]

添加元素:

my_list.append('world')      # 在末尾添加my_list.insert(1, 'new')     # 在指定位置插入print(my_list)               # [100, 'new', 2, 3, 'hello', True, 'world']list_a = [1, 2]list_b = [3, 4]list_c = list_a + list_b     # 连接列表,生成新列表print(list_c)                # [1, 2, 3, 4]list_a.extend(list_b)        # 将list_b的元素添加到list_a末尾print(list_a)                # [1, 2, 3, 4]

删除元素:

del my_list[1]               # 根据索引删除print(my_list)               # [100, 2, 3, 'hello', True, 'world']popped_element = my_list.pop() # 删除并返回最后一个元素print(popped_element)        # worldprint(my_list)               # [100, 2, 3, 'hello', True]my_list.remove(100)          # 删除第一个匹配的元素值print(my_list)               # [2, 3, 'hello', True]

其他常用操作:

len()

获取长度,

sort()

排序,

reverse()

反转,

count()

计数,

index()

查找索引。

2. NumPy

ndarray

的操作:

numpy

是Python进行科学计算的核心库,它的

ndarray

对象是多维同质数组,专为高效数值运算设计。

安装NumPy: 如果没安装,先

pip install numpy

创建数组:

import numpy as npnp_array_1d = np.array([1, 2, 3, 4, 5])np_array_2d = np.array([[1, 2, 3], [4, 5, 6]])print(np_array_1d)print(np_array_2d)# 常用创建函数zeros_array = np.zeros((2, 3))    # 全0数组ones_array = np.ones((3, 2))      # 全1数组range_array = np.arange(0, 10, 2) # 类似range,但生成ndarraylinspace_array = np.linspace(0, 1, 5) # 在指定区间内均匀生成N个点

访问元素与切片: 比列表更强大的多维切片。

print(np_array_2d[0, 1])       # 访问第一行第二列的元素:2print(np_array_2d[:, 0])       # 访问所有行的第一列:[1 4]print(np_array_2d[0, :])       # 访问第一行的所有元素:[1 2 3]print(np_array_2d[0:2, 1:3])   # 切片:[[2 3], [5 6]]# 布尔索引mask = np_array_1d > 3print(np_array_1d[mask])       # [4 5]

元素级运算: 这是

ndarray

的巨大优势,直接对整个数组进行数学运算。

a = np.array([1, 2, 3])b = np.array([4, 5, 6])print(a + b)                   # [5 7 9]print(a * 2)                   # [2 4 6]print(a * b)                   # 对应元素相乘:[4 10 18]print(np.sqrt(a))              # 逐元素求平方根

形状操作:

reshaped_array = np_array_1d.reshape((5, 1)) # 改变数组形状print(reshaped_array)print(np_array_2d.T)           # 转置

聚合函数

print(np_array_1d.sum())       # 数组所有元素之和print(np_array_2d.mean(axis=0)) # 沿列求平均值print(np_array_2d.max())       # 最大值

Python列表与NumPy数组有什么区别?

这个问题问得非常好,因为这是初学者最容易混淆,也是最核心的一个点。说实话,我刚开始学Python的时候,也觉得“不都是存数据嘛,有啥区别?”但随着项目深入,你会发现它们的设计哲学和应用场景是截然不同的。

从我的经验来看,主要区别体现在以下几个方面:

数据类型:

Python列表(

list

): 是异构的,这意味着一个列表中可以同时存储整数、浮点数、字符串、甚至其他列表或对象。这种灵活性很强,但代价是内存占用和访问效率。NumPy数组(

ndarray

): 是同构的,即所有元素必须是相同的数据类型(例如,全部是整数,或者全部是浮点数)。如果你尝试放入不同类型的数据,NumPy会尝试向上转型以保持同质性。这种特性让NumPy能将数据紧密地存储在内存中,从而实现高效的数值运算。

性能:

Python列表: 由于其异构性和动态大小的特性,列表中的每个元素实际上都存储为一个指向实际数据对象的指针。这意味着当你遍历列表或进行大量数值运算时,Python需要处理这些指针,导致性能开销较大,尤其是在处理大型数据集时。NumPy数组: 底层是用C语言实现的,数据是连续存储在内存中的。这使得NumPy在进行大规模数值运算时,可以利用CPU的SIMD(单指令多数据)指令集,并避免Python的解释器开销,因此速度非常快。对于科学计算、机器学习等场景,NumPy是不可或缺的。

功能和操作:

Python列表: 提供了非常通用的序列操作,比如

append

insert

pop

sort

等,更侧重于数据的组织和管理。NumPy数组: 提供了极其丰富的数学函数和操作,可以直接对整个数组进行元素级的算术运算(如加减乘除)、线性代数、傅里叶变换、随机数生成等。它的设计目标就是为了高效地处理数值数据。比如,两个NumPy数组相加,

array1 + array2

会直接进行对应元素的相加,而两个列表相加

list1 + list2

则是拼接操作。

什么时候用哪个?

list

当你需要存储不同类型的数据,或者数据结构经常变化(频繁增删),或者数据量不大且不涉及大量数值计算时,

list

是更简单、更直观的选择。

ndarray

当你处理的是大型数值数据集,需要进行高效的数学运算、统计分析,或者进行机器学习、深度学习等任务时,

numpy.ndarray

是绝对的首选。它的性能优势是列表无法比拟的。

Python数组的切片和索引技巧有哪些?

切片和索引是操作Python“数组”最基础也最强大的方式之一。掌握好它们,能让你在数据处理时事半功倍。我发现很多初学者对负数索引和多维数组的切片感到困惑,这里我们来详细聊聊。

1. Python列表(

list

)的切片与索引:

列表的索引是基于0的,这意味着第一个元素的索引是0,第二个是1,以此类推。

基本索引:

my_list = ['a', 'b', 'c', 'd', 'e']print(my_list[0])  # 'a'print(my_list[2])  # 'c'

负数索引: 负数索引从列表末尾开始计数。

-1

是最后一个元素,

-2

是倒数第二个,以此类推。这个真的非常方便,不用先

len(list) - 1

print(my_list[-1]) # 'e'print(my_list[-3]) # 'c'

切片(

[start:end:step]

): 切片会创建一个新列表,包含从

start

索引开始,到

end

索引(不包含)结束的元素。

step

是步长,默认为1。

start

省略:从头开始。

end

省略:到尾结束。

step

为负数:表示反向切片。

print(my_list[1:4])   # ['b', 'c', 'd'] (从索引1到索引3)print(my_list[:3])    # ['a', 'b', 'c'] (从头到索引2)print(my_list[2:])    # ['c', 'd', 'e'] (从索引2到尾)print(my_list[:])     # ['a', 'b', 'c', 'd', 'e'] (复制整个列表)print(my_list[::2])   # ['a', 'c', 'e'] (每隔一个取一个)print(my_list[::-1])  # ['e', 'd', 'c', 'b', 'a'] (反转列表,非常酷)

2. NumPy数组(

ndarray

)的切片与索引:

NumPy数组的索引和切片在单维度上与列表类似,但在多维数组上则展现出其真正的威力。

一维数组: 和列表几乎一样。

import numpy as nparr_1d = np.array([10, 20, 30, 40, 50])print(arr_1d[1])    # 20print(arr_1d[-2])   # 40print(arr_1d[1:4])  # [20 30 40]print(arr_1d[::-1]) # [50 40 30 20 10]

多维数组: 使用逗号分隔的索引来指定每个维度的位置。

arr_2d = np.array([[1, 2, 3],                   [4, 5, 6],                   [7, 8, 9]])print(arr_2d[0, 0])      # 1 (第一行第一列)print(arr_2d[1, 2])      # 6 (第二行第三列)print(arr_2d[0])         # [1 2 3] (访问第一行,等同于 arr_2d[0, :])

多维切片:

# 获取第一行和第二行的所有列print(arr_2d[0:2, :])    # 或者 arr_2d[:2, :]# 输出:# [[1 2 3]#  [4 5 6]]# 获取所有行的第二列print(arr_2d[:, 1])# 输出:# [2 5 8]# 获取中间的子矩阵print(arr_2d[1:3, 1:3])# 输出:# [[5 6]#  [8 9]]

步长切片:

arr_3d = np.arange(27).reshape((3, 3, 3))print(arr_3d[::2, ::2, ::2]) # 在所有维度上每隔一个取一个

布尔索引: 这是NumPy一个非常强大的特性,你可以用一个布尔数组来选择元素。

arr = np.array([10, 20, 30, 40, 50])mask = (arr > 25) & (arr < 45) # 创建一个布尔掩码print(mask)                    # [False False  True  True False]print(arr[mask])               # [30 40] (只选择True对应的元素)# 修改满足条件的元素arr[arr % 2 == 0] = 0          # 将所有偶数改为0print(arr)                     # [ 0 20  0 40  0]

整数数组索引: 使用一个整数数组作为索引,可以按任意顺序选择元素。

arr = np.array([10, 20, 30, 40, 50])indices = [0, 2, 4]print(arr[indices]) # [10 30 50]

掌握这些切片和索引的技巧,能让你在处理数据时更加灵活和高效,尤其是在数据分析和科学计算的场景中,这些操作是家常便饭。

Python中如何将列表转换为NumPy数组,反之亦然?

在实际的数据处理流程中,我们经常需要在Python的

list

和NumPy的

ndarray

之间进行转换。这通常发生在数据从外部源(比如CSV文件、数据库查询结果)加载进来时,它们可能最初以列表的形式存在,但为了进行高效的数值计算,我们需要将它们转换为NumPy数组。反过来,当你完成了NumPy数组的计算,可能需要将结果以列表的形式输出,或者与不接受NumPy数组的库进行交互。

1. Python列表转换为NumPy数组:

这是最常见的转换方向。NumPy提供了一个非常直观的函数

np.array()

来完成这个任务。

import numpy as np# 一维列表转一维NumPy数组my_list_1d = [1, 2, 3, 4, 5]np_array_1d = np.array(my_list_1d)print(f"列表: {my_list_1d}, 类型: {type(my_list_1d)}")print(f"NumPy数组: {np_array_1d}, 类型: {type(np_array_1d)}")# 输出:# 列表: [1, 2, 3, 4, 5], 类型: # NumPy数组: [1 2 3 4 5], 类型: # 二维列表(列表的列表)转二维NumPy数组my_list_2d = [[10, 20, 30], [40, 50, 60]]np_array_2d = np.array(my_list_2d)print(f"n二维列表:n{my_list_2d}")print(f"二维NumPy数组:n{np_array_2d}")# 输出:# 二维列表:# [[10, 20, 30], [40, 50, 60]]# 二维NumPy数组:# [[10 20 30]#  [40 50 60]]

需要注意的细节:

数据类型推断:

np.array()

会尝试推断列表元素的统一数据类型。如果列表包含混合类型,NumPy会向上转型以保持同质性。例如,如果列表中有整数和浮点数,它会全部转为浮点数。

mixed_list = [1, 2.5, 3]mixed_np_array = np.array(mixed_list)print(mixed_np_array)      # [1.  2.5 3. ]print(mixed_np_array.dtype) # float64

深拷贝: 默认情况下,

np.array()

会创建一个原始列表的深拷贝,这意味着修改NumPy数组不会影响原始列表,反之亦然。这通常是你想要的行为。

original_list = [1, 2, 3]arr = np.array(original_list)arr[0] = 99print(original_list) # [1, 2, 3] (未改变)print(arr)           # [99  2  3]

2. NumPy数组转换为Python列表:

NumPy数组对象有一个

tolist()

方法,可以方便地将其转换为Python列表。对于多维数组,它会生成一个嵌套的列表。

# 一维NumPy数组转一维列表np_array_1d = np

以上就是Python中数组如何操作 Python中数组操作教程的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1368997.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月14日 09:15:48
下一篇 2025年12月14日 09:16:01

相关推荐

  • Python中模块导入方法详解 Python中import使用指南

    Python模块导入的核心是import语句,它通过sys.path搜索路径加载模块,支持import module、from module import object、别名导入及相对导入等多种方式,合理选择可避免命名冲突、循环导入等问题,提升代码可维护性。 Python中模块导入的核心在于 imp…

    2025年12月14日
    000
  • Python中文件怎么读写 Python中文件读写操作指南

    Python文件读写核心是使用open()函数打开文件,通过read()、write()等方法操作内容,并用with语句确保文件安全关闭。 Python中文件读写,核心在于使用内置的 open() 函数来打开文件,然后根据你想要进行的操作(读取、写入或追加)选择合适的模式。之后,通过文件对象提供的各…

    2025年12月14日
    000
  • Python中字典遍历的几种方式 Python中字典遍历方法示例

    Python中遍历字典主要有三种方式:直接遍历键、使用values()遍历值、使用items()遍历键值对;选择依据是所需数据类型,其中items()最Pythonic;自Python 3.7起,字典保持插入顺序;遍历时直接修改字典会引发错误,应通过副本或新建字典来安全操作。 Python中遍历字典…

    2025年12月14日
    000
  • Python如何操作集合_Python集合使用方法归纳

    Python集合是无序、不重复元素的容器,适用于去重、快速成员检测及数学集合运算。 Python集合,在我看来,是处理数据去重和执行数学集合运算时,一个极其高效且优雅的工具。它本质上是一个无序且不包含重复元素的容器。你可以通过字面量 {} (但注意, {} 创建的是空字典,空集合需要用 set() …

    2025年12月14日
    000
  • Python中排序算法如何实现 Python中排序算法详解

    选择合适的排序算法需根据数据规模、特性、内存限制和稳定性需求综合判断,Python内置sort()和sorted()方法高效且支持自定义key函数实现灵活排序,实际应用中推荐使用内置方法而非手动实现。 Python中排序算法的实现,本质上是将一系列无序的数据,通过特定的步骤,最终变成有序排列的过程。…

    2025年12月14日
    000
  • Python中递归函数如何编写 Python中递归函数详解

    递归函数的核心是函数自我调用并设停手条件。首先确定基线条件(如n≤1时返回n),再定义递归步骤(如fibonacci(n-1)+fibonacci(n-2)),确保问题规模缩小。常见陷阱包括无限递归导致的RecursionError和重复计算带来的性能问题,可通过记忆化(缓存已计算结果)优化。递归适…

    2025年12月14日
    000
  • python怎么连接mysql数据库_python数据库操作指南

    Python连接MySQL需使用PyMySQL等库作为“桥梁”,通过API发送SQL指令。首先安装库并建立连接,注意配置host、user、password等参数,推荐使用环境变量避免硬编码。常见认证问题包括用户名密码错误、权限不足(如’@localhost’与’…

    2025年12月14日
    000
  • Python中装饰器怎么用 Python中装饰器使用指南

    装饰器是Python中用于包装或修改函数、方法或类行为的高阶函数,无需修改原代码即可添加日志、计时、权限校验等横切关注点。其核心语法为@decorator_name,本质是将函数作为参数传入装饰器并返回新函数。使用functools.wraps可保留原函数元信息,避免调试困难。带参数的装饰器需多一层…

    2025年12月14日
    000
  • Python如何实现排序_Python排序算法与应用实例

    Python内置排序基于Timsort算法,结合归并排序与插入排序,兼具高效性与稳定性,适用于绝大多数场景;日常开发应优先使用list.sort()或sorted(),仅在学习、特定数据分布或极端优化需求下才考虑手写排序算法。 Python实现排序主要依赖其内置的 list.sort() 方法和 s…

    2025年12月14日
    000
  • Python如何操作Excel_Python读写Excel文件方法归纳

    Python操作Excel推荐根据需求选择库:处理.xlsx文件且需单元格级控制时用openpyxl;进行数据分析和批量处理时首选pandas;兼容旧版.xls文件可使用xlrd和xlwt;生成复杂报表且仅需写入时选用xlsxwriter。openpyxl支持读写及样式、合并单元格等精细控制,适合自…

    2025年12月14日
    000
  • Python怎样画图表_Python数据可视化绘图教程汇总

    Python中常用Matplotlib、Seaborn、Plotly等库进行数据可视化,适用于不同场景:Matplotlib适合基础绘图与高度自定义,Seaborn擅长统计分析与美观图表,Plotly用于交互式Web图表。常见图表包括折线图(趋势)、散点图(关系)、柱状图(比较)、直方图(分布)、箱…

    2025年12月14日
    000
  • Python中文件读写操作教程 Python中open函数用法解析

    答案:Python文件操作以open()函数为核心,配合with语句可安全高效地读写文件;处理大文件时应采用流式读取或分块写入,避免内存溢出;编码需明确指定为utf-8以防乱码,关键数据更新宜用临时文件加原子替换策略,确保数据完整性。 Python的文件读写操作,说白了,就是程序与外部数据交互的桥梁…

    2025年12月14日
    000
  • Python中优化嵌套循环数值计算的Numba加速指南

    本文旨在提供一套实用的教程,指导如何在Python中通过Numba库显著提升深度嵌套循环的数值计算性能。我们将探讨如何利用Numba的JIT(Just-In-Time)编译功能,以及进一步结合其并行计算能力(prange),将原本耗时数十分钟甚至更长的计算任务,优化至秒级完成,从而有效应对大规模科学…

    2025年12月14日
    000
  • Python中try except异常处理教程 Python中异常捕获方法详解

    答案:Python中通过try-except机制优雅处理异常,提升代码健壮性;应避免空except和过度捕获,推荐使用具体异常类型、精简try块、finally资源清理,并提倡EAFP编程风格与自定义异常以增强可维护性。 Python编程中,错误和意外情况是常态,而 try-except 机制正是我…

    2025年12月14日
    000
  • Python怎么使用NumPy库_NumPy数组操作教程一览

    NumPy是Python科学计算的核心库,提供高性能多维数组ndarray及向量化操作工具。通过import numpy as np导入后,可使用np.array()、np.zeros()、np.ones()、np.linspace()等函数创建数组,相比Python列表,ndarray存储同类型数…

    2025年12月14日
    000
  • Python中列表如何添加元素 Python中列表添加元素方法

    Python中向列表添加元素有append()、insert()、extend()和+运算符四种主要方式。append()用于在末尾添加单个元素;insert()可在指定位置插入元素,但频繁使用尤其在列表开头插入时性能较差,时间复杂度为O(n);extend()适用于将可迭代对象的元素逐个添加到列表…

    2025年12月14日
    000
  • Python中爬虫如何编写 Python中爬虫入门教程

    Python爬虫核心库是requests和BeautifulSoup,前者用于发送HTTP请求,后者用于解析HTML;面对动态内容可用Selenium模拟浏览器行为,应对反爬机制需设置请求头、控制频率、处理登录等;同时必须遵守robots.txt、服务条款,尊重隐私与版权,避免对服务器造成负担。 P…

    2025年12月14日
    000
  • 使用 Numba 加速 Python 嵌套循环

    本文将探讨如何使用 Numba 库中的 Just-In-Time (JIT) 编译器来显著提升 Python 中嵌套循环的执行速度。通过简单的装饰器 @njit 和 prange,可以将耗时的循环计算加速数十倍,尤其是在涉及大量数值计算的场景中。此外,文章还展示了如何通过存储中间结果来进一步优化代码…

    2025年12月14日
    000
  • python怎么创建列表_python列表操作完全指南

    Python创建列表最常用方式是用方括号[]直接定义,如my_list = [1, 2, 3];也可用list()构造函数转换可迭代对象,或使用列表推导式[expr for item in iterable if cond]实现简洁高效的列表生成;列表支持通过索引和切片访问及修改元素,结合appen…

    2025年12月14日
    000
  • Python中上下文管理器怎么用 Python中上下文管理器指南

    Python上下文管理器解决了资源管理中的泄露风险和代码冗余问题,通过with语句自动处理资源的获取与释放,确保异常安全。它广泛应用于文件操作、数据库事务、线程锁、环境切换和测试mock等场景,提升代码的可读性、健壮性和复用性,核心实现方式包括类定义__enter__和__exit__方法,或使用c…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信