Python常用库(六):科学计算库-Numpy[上篇]:创建、访问、赋值

news2024/9/28 15:19:50

1.Numpy

1.1 介绍

NumPyPython中非常流行且重要的科学计算库,提供了一个强大的多维数组对象(ndarray)和许多数学操作,包括矩阵运算、线性代数、微积分等等。

numpyPython中一个非常有用的工具,特别是在需要进行数值计算、线性代数计算、数据分析和机器学习等领域。

其他资料:

  • GitHub截止当前: 24.4k https://github.com/numpy/numpy

  • 中文文档: https://www.numpy.org.cn/

1.2 主要功能

以下是NumPy的主要功能:

  • 多维数组 (ndarray): NumPy的核心功能是多维数组对象 ndarray,它是一个固定大小的数组,在内存中连续存储数据。 ndarray可以保存任何类型的数据, 但通常用于存储数值类型的数据。 ndarray的维度可以从一维到多维,可以进行基本的数值操作 (加法、减法、乘法、除法等) 以及矩阵运算 (矩阵乘法、矩阵转置等)。
  • 数组操作: NumPy提供了一系列用于数组操作的函数和方法。可以对数组进行形状调整 ( reshape) 、切片( slicing) 、索引 ( indexing) 和切割 ( splitting) 等操作。 这些操作高效地对数组进行重排、选取和修改。
  • 数学函数: NumPy提供了大量的数学函数,如三角函数、指数函数、对数函数等。这些函数可以直接应用于数组,并进行元素级的操作。此外, NumPy还提供了统计学函数 (均值、方差、相关性等)、线性代数函数 (矩阵求逆、特征值分解等) 等。
  • 文件I/0: NumPy提供了用于读写数组数据的函数。可以将数组数据保存至文件 (如 CSV、HDF5等格式) 或从文件中加载数据。这对于在机器学习中保存和加载数据集非常有用。
  • 广播 (Broadcasting) : 广播是 NumPy中的强大功能之一。它允许在不同形状的数组间进行数值运算,而无需进行显式的形状匹配或复制数据。通过广播, 可以对形状不同的数组进行运算,使得代码更加简洁和高效。
  • 并行计算: NumPy支持并行计算和向量化操作。通过使用 NumPy的通用函数 ( ufunc) ,可以在数组上进行并行计算,提高计算效率。此外, NumPy还与其他库 (如 SciPy) 和工具(如 Numba) 集成,可进一步提升计算性能。

1.3 安装

通过Anaconda安装的Python环境,默认会安装Numpy

# 查看当前环境是否安装
(py3.11) ➜  python-learn pip list | grep num
numexpr                   2.8.4
numpy                     1.25.2
# 不存在则通过下面命令安装
(py3.11) ➜ pip install numpy 

2. 创建数组

2.1 序列转数组

numpy.array函数可以将Python列表或元组转换为NumPy数组。例如:

import numpy as np

if __name__ == '__main__':
    # 使用numpy.array创建多维数组
    print("------------创建一维数组--------------------")
    list_one = np.array([123])
    tuple_one = np.array((123))
    print("列表转一维:{} \n元组转一维:{}".format(list_one, tuple_one))

    print("------------创建二维数组--------------------")
    list_two = np.array([
        [123],
        [456],
        [789],
    ])
    tuple_two = np.array((
        (123),
        (456),
        (789),
    ))
    print("列表转二维:\n {} \n元组转二维:{}".format(list_two, tuple_two))

    print("------------创建三维数组--------------------")
    list_three = np.array([
        [
            [123],
        ],
        [
            [456],
        ],
        [
            [789]
        ]
    ])
    print("列表转三维:{} ".format(list_three))
    
# ********************** 输出 **********************
------------创建一维数组--------------------
列表转一维:[1 2 3
元组转一维:[1 2 3]
------------创建二维数组--------------------
列表转二维:
 [[1 2 3]
 [4 5 6]
 [7 8 9]] 
元组转二维:[[1 2 3]
 [4 5 6]
 [7 8 9]]
------------创建三维数组--------------------
列表转三维:[[[1 2 3]]

 [[4 5 6]]

 [[7 8 9]]] 

2.2 一维数组

numpy库中,我们可以通过numpy.arangenumpy.linspace来创建一维数组,它们的主要区别在于参数的定义方式和生成数组的规则。

1. numpy.arange
numpy.arange([start, ]stop, [step, ]dtype=None)
  • start:起始值(包含在数组中)。
  • stop:终止值(不包含在数组中)。
  • step:步长,可选参数,默认为1。
  • dtype:可选参数,指定数组的数据类型。

使用示例:

import numpy as np
if __name__ == '__main__':
    print("np.arange(10):", np.arange(10))
    print("np.arange(5, 10):", np.arange(510))
    print("np.arange(0, 10, 3):", np.arange(0103))
    
# -------------------------- 输出 --------------------------
np.arange(10): [0 1 2 3 4 5 6 7 8 9]
np.arange(510): [5 6 7 8 9]
np.arange(0103): [0 3 6 9]
2. numpy.linspace
linspace(start, stop, num=50, endpoint=True, retstep=False, dtype=None)
  • start:起始值(包含)。
  • stop:终止值(默认包含,可根据参数 endpoint调整)。
  • num:可选参数,默认为 50,指定数组的长度(元素个数)。
  • endpoint:可选参数,默认为 True,如果为 True,终止值( stop)将包含在数组中;如果为 False,终止值不包含在数组中。
  • retstep:可选参数,默认为 False,如果为 True,将会返回数组的取值间隔。
  • dtype:可选参数,指定数组的数据类型。

使用示例:

import numpy as np
if __name__ == '__main__':
    print("在 [0,10]之间取5个元素:", np.linspace(0105))
    print("在 [0,10]之间取5个元素,并返回取值间隔:", np.linspace(0105, retstep=True))
    print("在 [0,10)之间取5个元素,不包含10:", np.linspace(0105, endpoint=False))
    
# --------------------- 输出 ---------------------
在 [0,10]之间取5个元素: [ 0.   2.5  5.   7.5 10. ]
在 [0,10]之间取5个元素,不包含10: [0. 2. 4. 6. 8.]
在 [0,10]之间取5个元素,并返回取值间隔: (array([ 0. ,  2.5,  5. ,  7.510. ]), 2.5)

@使用说明: 至于到底选择使用哪个函数,取决于您希望如何生成一维数组。

  • 依据 步长生成,用 numpy.arange
  • 依据 元素个数生成,用 numpy.linspace

2.3 特别数组

  • numpy.zeros: 该函数可以创建指定形状的数组,并将所有元素初始化为 0
  • numpy.ones: 该函数可以创建指定形状的数组,并将所有元素初始化为 1
import numpy as np

if __name__ == '__main__':
    print("---------------------------- 全是0 ------------------------------------")
    print("一维数组-> np.zeros(6):", np.zeros(6))
    print("二维数组(2,3)-> np.zeros((2,3)):", np.zeros((23)))
    print("三维数组(2,3,3)-> np.zeros((2,2,3)):", np.zeros((223)))
    print("---------------------------- 全是1 ------------------------------------")
    print("一维数组-> np.ones(6):", np.ones(6))
    print("二维数组(2,3)-> np.ones((2,3)):", np.ones((23)))
    print("三维数组(2,3,3)-> np.ones((2,2,3)):", np.ones((223)))
    
# ********************************* 输出 *********************************
---------------------------- 全是0 ------------------------------------
一维数组-> np.zeros(6): [0. 0. 0. 0. 0. 0.]
二维数组(2,3)-> np.zeros((2,3)): [[0. 0. 0.]
 [0. 0. 0.]]
三维数组(2,3,3)-> np.zeros((2,2,3)): [[[0. 0. 0.]
  [0. 0. 0.]]

 [[0. 0. 0.]
  [0. 0. 0.]]]
---------------------------- 全是1 ------------------------------------
一维数组-> np.ones(6): [1. 1. 1. 1. 1. 1.]
二维数组(2,3)-> np.ones((2,3)): [[1. 1. 1.]
 [1. 1. 1.]]
三维数组(2,3,3)-> np.ones((2,2,3)): [[[1. 1. 1.]
  [1. 1. 1.]]

 [[1. 1. 1.]
  [1. 1. 1.]]]

2.4 空数组

NumPy中的empty函数是用于创建一个指定形状和数据类型的空数组。它会分配内存空间来存储数组元素,但不会对这些元素进行初始化。因此,创建的数组将包含未初始化的随机值或者之前内存中遗留的值。

numpy.empty(shape, dtype=float, order='C')

1.参数说明:

  • shape:表示所需的数组形状,可以是一个整数或者一个整数元组。
  • dtype(可选):表示所需的数组元素的数据类型,默认为 float
  • order(可选):表示数组在内存中的存储顺序,可以是'C'(按行存储)或'F'(按列存储),默认为'C'。

2.使用示例:

import numpy as np
if __name__ == '__main__':
    print("二维数组:\n", np.empty((23)))
    print("三维数组:\n", np.empty((222)))
    
# --------------------- 输出 ---------------------
/Users/liuqh/opt/anaconda3/envs/py3.11/bin/python /Users/liuqh/ProjectItem/PythonItem/python-learn/main.py 
二维数组:
 [[0.   0.15 0.25]
 [0.5  0.75 1.  ]]
三维数组:
 [[[0.    0.03 ]
  [0.215 0.4  ]]

 [[0.586 0.77 ]
  [0.954 1.   ]]]

2.5 随机数组

NumPy有一个random子模块,可以用来创建随机数组,该模块下有三个常用的函数:

  • np.random.random: 用于生成 [0,1) 区间内的随机浮点型数组;

    def random(size=None):
    # size: 用于指定数组元素个数  
  • np.random.randint: 用于生成[low, high)区间内的随机整型数组

    def randint(low, high=None, size=None, dtype=None)
    low:
     区间最小值(包含)
    # high: 区间最大值(不包含)
    # size:是一个元组,用于指定数组形状
    # dtype: 用于指定数组类型
  • np.random.random: 用于生成以loc为均值、以scale为标准差的正态分布数组;

    def normal(loc=0.0, scale=1.0, size=None)
    loc:
    均值
    # size:是一个元组,用于指定数组形状

代码示例:

import numpy as np

if __name__ == '__main__':
    print("------------- np.random.random 演示 -------------")
    random_var = np.random.random(4)
    print("random_var:", random_var)
    print("random_var.shape:", random_var.shape)
    print("------------- np.random.randint 演示 -------------")
    rand_int = np.random.randint(110, size=(23))
    print("rand_int:", rand_int)
    print("rand_int.shape:", rand_int.shape)
    print("------------- np.random.randint 演示 -------------")
    rand_normal = np.random.normal(size=(33))
    print("rand_normal:", rand_normal)
    print("rand_normal.shape:", rand_normal.shape)

# ******************** 输出 *******************
------------- np.random.random 演示 -------------
random_var: [0.61308029 0.45486095 0.69006646 0.38384838]
random_var.shape: (4,)
------------- np.random.randint 演示 -------------
rand_int: [[9 4 9]
 [7 4 3]]
rand_int.shape: (23)
------------- np.random.randint 演示 -------------
rand_normal: [[ 1.93567259  1.21137246  0.128895  ]
 [-2.28372489  0.63390644  0.48948102]
 [ 0.34386644  0.3941035   0.60806804]]
rand_normal.shape: (33)

3. 数组属性

3.1 常用属性

属性说明
shape数组的形状
ndim数组的维度
dtype数组元素的数据类型
size数组元素的总数

3.2 元素类型

if __name__ == '__main__':
    # 所有数据类型
    print("所有数据类型:", np.sctypeDict.values())

    # 定义数组,dtype=np.int32
    arr = np.arange(08, dtype=np.int32)
    print("打印数组:", arr)
    print("数组类型.dtype:", arr.dtype)

    # 类型转换
    new_arr = arr.astype(np.int64)
    print("类型转换后.dtype:", new_arr.dtype)
    
# ----------------------输出---------------------
所有数据类型: dict_values([...]) # 类型太多,此处省略
打印数组: [0 1 2 3 4 5 6 7]
数组类型.dtype: int32
类型转换后.dtype: int64

@注意:NumPy的数值对象的运算速度比Python的内置类型的运算速度慢很多,如果程序中需要大量地对单个数值运算,应尽量使用Python的内置类型

3.3 使用示例

import numpy as np
if __name__ == '__main__':
    print("----------------------------------------------------------")
    # 定义一维数组
    one_arr = np.arange(4, dtype=np.int32)
    print("一维数组:\n", one_arr)
    # 定义二维数组
    two_arr = np.arange(6, dtype=float).reshape(23)
    print("二维数组:\n", two_arr)
    # 定义多维数组
    three_arr = np.arange(012, dtype=int).reshape((223))
    print("三维数组:\n", three_arr)
    print("---------------------- 数组的维度 --------------------------")
    print("one_arr.ndim:", one_arr.ndim)
    print("two_arr.ndim:", two_arr.ndim)
    print("three_arr.ndim:", three_arr.ndim)
    print("---------------------- 数组的形状 --------------------------")
    print("one_arr.shape:", one_arr.shape)
    print("two_arr.shape:", two_arr.shape)
    print("three_arr.shape:", three_arr.shape)
    print("---------------------- 数组元素的总数 -----------------------")
    print("one_arr.size:", one_arr.size)
    print("two_arr.size:", two_arr.size)
    print("three_arr.size:", three_arr.size)
    print("---------------------- 数组元素类型 -------------------------")
    print("one_arr.dtype:", one_arr.dtype)
    print("two_arr.dtype:", two_arr.dtype)
    print("three_arr.dtype:", three_arr.dtype)
    
# **************************** 输出 *****************************
----------------------------------------------------------
一维数组:
 [0 1 2 3]
二维数组:
 [[0. 1. 2.]
 [3. 4. 5.]]
三维数组:
 [[[ 0  1  2]
  [ 3  4  5]]

 [[ 6  7  8]
  [ 9 10 11]]]
---------------------- 数组的维度 --------------------------
one_arr.ndim: 1
two_arr.ndim: 2
three_arr.ndim: 3
---------------------- 数组的形状 --------------------------
one_arr.shape: (4,)
two_arr.shape: (23)
three_arr.shape: (223)
---------------------- 数组元素的总数 -----------------------
one_arr.size: 4
two_arr.size: 6
three_arr.size: 12
---------------------- 数组元素类型 --------------------------
one_arr.dtype: int32
two_arr.dtype: float64
three_arr.dtype: int64

4. 数组访问

4.1 维度理解

可耻盗张图,侵权联系删
可耻盗张图,侵权联系删

当维度大于1时,axis=x含义如下:

  • axis=0: 代表对横轴操作,即第几行
  • axis=1: 代表对纵轴操作,即第几列
  • axis=2: 代表对层级操作,即第几层

@注:上述说明也许过于浅显,要是更好的多维理解文章,求推荐。

4.2 访问语法

一维数组的访问方式和列表一样,这里不在叙述;这里主要学习二维和三维数组的访问方式,访问语法如下:

# 当访问二维数组时
arr[x,y] 或 arr[x][y]
# 当访问三维数组时
arr[c,x,y] 或 arr[c][x][y]
  • x: 指第几行,从0开始,如: arr[0]代表访问第一行,
  • y: 指第几列,从0开始,如: arr[0,0] 代表访问第一行第一列
  • c: 指第几层,从0开始,如: arr[0,0,0]代表访问第一层第一行第一列

代码示例:

import numpy as np

if __name__ == '__main__':
    arr = np.arange(6).reshape((23))
    print("----------------------- 二维数组访问 -----------------------")
    print("二维数组:\n", arr)
    print("第2行第3列:", arr[12])
    print("@第2行第3列:", arr[1][2])
    three_arr = np.arange(12).reshape((232))
    print("----------------------- 三维数组访问 -----------------------")
    print("三维数组:\n", three_arr)
    print("第1层第2行第2列:", three_arr[011])
    print("@第1层第2行第2列:", three_arr[0][1][1])
    print("第2层第3行第1列:", three_arr[120])
    print("@第2层第3行第1列:", three_arr[1][2][0])
    
# *********************** 输出 ***********************
----------------------- 二维数组访问 -----------------------
二维数组:
 [[0 1 2]
 [3 4 5]]
2行第3列: 5
@第2行第3列: 5
----------------------- 三维数组访问 -----------------------
三维数组:
 [[[ 0  1]
  [ 2  3]
  [ 4  5]]

 [[ 6  7]
  [ 8  9]
  [10 11]]]
1层第2行第2列: 3
@第1层第2行第2列: 3
2层第3行第1列: 10
@第2层第3行第1列: 10

@注: A[x,y]和A[x][y]两者是有区别的。A[x,y]只进行一次计算,直接获取数组中行为x、列为y的元素;而A[x][y]进行了两次计算:首先获取A[x]对应的数据集合(是第x行的数据集合),然后在获取的新数据集合中获取第y个元素。建议使用A[x,y]这种方式获取数组元素

4.3 切片索引

访问数组时,切片索引下标说明:

arr[x:y:z]
  • x: 指从哪儿开始,包括当前元素,默认0;

  • y: 指到哪儿结束, 不包括当前元素,默认到最后;

  • z: 指间隔多少取一次元素,默认1;

使用切片索引时,一定要注意索引中的逗号(,)

这里以**三维数组:arr[层,行,列]**为例,列举几个访问方式:

  • arr[0]: 访问三维数组中的第一层;
  • arr[0,:,0]: 这里 被写成** :**,指访问第1层所有行中的第1列;
  • arr[0,0,:]: 这里 被写成** :**,指访问第1层第1行中的所有列;
  • arr[0,0,0]: 指访问第1层第1行第1列对应的元素;
  • arr[1,0,0:2]: 指访问第2层第1行,第1、2列的元素, 0:2中的0可以省略即: arr[1,0,:2]
  • arr[1, 0, ::2]: 指在第2层第1行所有元素中,每间隔2个元素取一次
import numpy as np

if __name__ == '__main__':
    arr = np.arange(18).reshape((233))
    print("三维数组:\n", arr)

    print("第1层:\n", arr[0])
    print("第1层所有行中的第1列:", arr[0, :, 0])
    print("第1层第1行中的所有列:", arr[00, :])
    print("第1层第1行第1列元素:", arr[000])
    print("第2层第1行第1、2列元素:", arr[10, :2])
    print("在第2层第1行所有元素中,每间隔2个元素取一次:", arr[10, ::2])
    
# *************** 输出 ****************
三维数组:
 [[[ 0  1  2]
  [ 3  4  5]
  [ 6  7  8]]

 [[ 9 10 11]
  [12 13 14]
  [15 16 17]]]
1层:
 [[0 1 2]
 [3 4 5]
 [6 7 8]]
1层所有行中的第1列: [0 3 6]
1层第1行中的所有列: [0 1 2]
1层第1行第1列元素: 0
2层第1行第12列元素: [ 9 10]
在第2层第1行所有元素中,每间隔2个元素取一次: [ 9 11]

@注意:使用切片得到的数组,底层依旧指向原来的数组,修改切片元素,也会影响到原始数组(引用变量), 如下示例:

import numpy as np
if __name__ == '__main__':
    arr = np.arange(5)
    print("arr:", arr)
    # 通过切片得到新数组
    slice_arr = arr[2:4]
    print("slice_arr:", slice_arr)
    # 修改切片数组
    slice_arr[0] = 100
    print("修改切片数组后 slice_arr:", slice_arr)
    print("修改切片数组后 arr:", arr)

# ---------------------- 输出 ----------------------
arr: [0 1 2 3 4]
slice_arr: [2 3]
修改切片数组后 slice_arr: [100   3]
修改切片数组后 arr: [  0   1 100   3   4]

4.4 布尔索引

NumPy中,布尔索引是一种非常强大和灵活的索引方式,它允许我们根据指定的条件来获取数组中满足该条件的元素,并且返回一个与原始数组形状相同的布尔数组,其中对应位置上的元素是TrueFalse

1.常用表达式:

表达式说明
==相等;如:arr == 3
!=不等;如:arr != 3
><大于和小于; 如: arr > 3
&并且(and),都为真则为True
``
~逻辑非,即相反的条件

2.使用示例:

if __name__ == '__main__':
    print("-------------------- 根据条件输出匹配结果 --------------------")
    arr = np.array(["Python""Go""C""PHP""Java"])
    # 匹配等于条件
    print("等于'Go'的元素变成True:\n{}\n{}".format(arr, arr == "Go"))
    # 匹配相反(~)条件 
    opposite_conda = ~(arr == "Go")
    print("不等于'Go'的元素变成True:\n{}\n{}".format(arr, opposite_conda))

    # 匹配大于条件: 大于2的元素
    num_arr = np.arange(6)
    print("大于2的元素变成True:\n{}\n{}".format(num_arr, num_arr > 2))
    # 匹配&(and)条件: 大于2且被2整除
    cond = (num_arr > 2) & (num_arr % 2 == 0)
    print("大于2且被2整除的元素变成True:\n{}\n{}".format(num_arr, cond))
    # 匹配|(or)条件: 大于4或被2整除
    or_cond = (num_arr > 4) | (num_arr % 2 == 0)
    print("大于4或被2整除的元素变成True:\n{}\n{}".format(num_arr, or_cond))

# ******************************* 输出 **************************
--------------------  根据条件输出匹配结果 -------------------- 
等于'Go'的元素变成True:
['Python' 'Go' 'C' 'PHP' 'Java']
[False  True False False False]
不等于'Go'的元素变成True:
['Python' 'Go' 'C' 'PHP' 'Java']
True False  True  True  True]
大于2的元素变成True:
[0 1 2 3 4 5]
[False False False  True  True  True]
大于2且被2整除的元素变成True:
[0 1 2 3 4 5]
[False False False False  True False]
大于4或被2整除的元素变成True:
[0 1 2 3 4 5]
True False  True False  True  True]   

4.5 数组索引

Numpy中除了使用整数索引、切片索引还可以使用数组索引,数组索引一般分为:一维数组和多维数组

  • arr[[1,3,5]]: 当索引是一维数组时,代表访问数组 arr索引( 或行)为 1、3、5的元素;
  • arr[ [0,1], [1,2] ]: 当索引是多维数组时,代表访问数组 arr, (0,1)、(1,2)对应的元素;
import numpy as np

if __name__ == '__main__':
    print("---------------- 一维索引数组演示 ----------------")
    one_arr = np.arange(1122)
    print("一维数组:\n", one_arr)
    # 代表访问 one_arr[1]、one_arr[3]、one_arr[5] 对应的元素
    print("当索引是一维数组时(访问一维):", one_arr[[135]])

    tmp_arr = np.arange(12).reshape(43)
    print("二维数组:\n", tmp_arr)
    # 代表访问 tmp_arr[1]、tmp_arr[3] 对应的行
    print("当索引是一维数组时(访问二维): \n", tmp_arr[[13]])

    print("---------------- 多维索引数组演示 ----------------")
    arr = np.arange(6).reshape(23)
    print("二维数组:\n", arr)
    # [0,1]: 第1行第2列元素
    # [1,2]: 第2行第3列元素
    a = arr[[01], [12]]
    print("当索引是二维数组时:", a)
    
# ******************** 输出 ********************
---------------- 一维索引数组演示 ----------------
一维数组:
 [ 1  3  5  7  9 11]
当索引是一维数组时(访问一维): [ 3  7 11]
二维数组:
 [[ 0  1  2]
 [ 3  4  5]
 [ 6  7  8]
 [ 9 10 11]]
当索引是一维数组时(访问二维): 
 [[ 3  4  5]
 [ 9 10 11]]
---------------- 多维索引数组演示 ----------------
二维数组:
 [[0 1 2]
 [3 4 5]]
当索引是二维数组时: [1 5]

5.数组赋值

5.1 普通索引赋值

import numpy as np

if __name__ == '__main__':
    arr = np.arange(6).reshape(23)
    print("原始数组:\n", arr)
    # 使用普通索引赋值
    oldVal = arr[12]
    newVal = oldVal * oldVal
    arr[12] = newVal
    print("把arr[1,2]对应元素:{},改成:{}".format(oldVal, newVal))
    print("修改后的数组:\n", arr)
    
# ******************** 输出 ********************
原始数组:
 [[0 1 2]
 [3 4 5]]
把arr[1,2]对应元素:5,改成:25
修改后的数组:
 [[ 0  1  2]
 [ 3  4 25]]

5.2 切片索引赋值

import numpy as np

if __name__ == '__main__':
    arr = np.arange(12).reshape(43)
    print("原始数组:\n", arr)
    # 修改整行中所有的元素
    arr[0, :] = 99
    print("修改数组第1行所有元素后:\n", arr)
    # 修改所有行中第2列元素
    arr[:, 1] = 88
    print("修改所有行中第2列元素后:\n", arr)

# ******************** 输出 ********************
原始数组:
 [[ 0  1  2]
 [ 3  4  5]
 [ 6  7  8]
 [ 9 10 11]]
修改数组第1行所有元素后:
 [[99 99 99]
 [ 3  4  5]
 [ 6  7  8]
 [ 9 10 11]]
修改所有行中第2列元素后:
 [[99 88 99]
 [ 3 88  5]
 [ 6 88  8]
 [ 9 88 11]]

5.3 布尔索引赋值

import numpy as np

if __name__ == '__main__':
    arr = np.arange(6)
    print("原始数组:", arr)
    index = (arr % 2 == 0)
    print("布尔索引:", index)
    # 被2整除的元素,都乘以2
    arr[index] *= 2
    print("被2整除的元素,都乘以2:", arr)
    # 大于3的元素,都设置成0
    arr[arr > 3] = 0
    print("大于3的元素,都设成0: ", arr)

   
# ******************** 输出 ********************
原始数组: [0 1 2 3 4 5]
布尔索引: [ True False  True False  True False]
2整除的元素,都乘以2: [0 1 4 3 8 5]
大于3的元素,都设成0:  [0 1 0 3 0 0]

本文由 mdnice 多平台发布

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于nRF7002-DK的NFC功能切换系统(nRF Connect SDK+NFC)

目录 项目介绍硬件介绍项目设计开发环境及工程目录总体流程图硬件初始化NFC功能实现文本记录安卓应用打开按键切换功能 功能展示项目总结 &#x1f449; 【Funpack2-6】基于nRF7002-DK的NFC功能切换系统 &#x1f449; Github: EmbeddedCamerata/nRF7002-DK-nfc-function-switc…

智慧养殖:浅谈视频监控与AI智能识别技术助力奶牛高效、智慧养殖

一、方案背景 随着科技的飞速发展&#xff0c;智能化养殖逐渐成为现代畜牧业的发展趋势。人工智能技术、物联网、视频技术、云计算、大数据等新兴技术&#xff0c;正在为奶牛养殖业带来全新的变革。越来越多的牧场、养殖场开始运用新技术来进行智能监管、提高生产效率、降低生…

就只说 3 个 Java 面试题

在面试时&#xff0c;即使是经验丰富的开发人员&#xff0c;也可能会发现这是一些很棘手的问题&#xff1a; 1、Java中“transient”关键字的用途是什么&#xff1f;如何才能实现这一目标&#xff1f; 在 Java 中&#xff0c;“transient”关键字用于指示类的特定字段不应包含…

蒙特卡洛方法的数学基础-1

蒙特卡洛方法的数学基础-1 概率论 Bayes 公式 常用分布 Binominal Distribution Poisson Distribution Gaussian Distribution Exponential Distribution Uniform Distribution 大数定理 均匀概率分布随机地取N个数xi &#xff0c;函数值之和的算术平均收敛于函数的期望值 …

Cesium 空间量算——生成点位坐标

文章目录 需求分析1. 点击坐标点实现2. 输入坐标实现 需求 用 Cesium 生成点位坐标&#xff0c;并明显标识 分析 以下是我的两种实现方式 第一种是坐标点击实现 第二种是输入坐标实现 1. 点击坐标点实现 //点位坐标getLocation() {this.hoverIndex 0;let that this;this.view…

八一书《乡村振兴战略下传统村落文化旅游设计》许少辉瑞博士生辉少许——2023学生开学季许多少年辉光三农

八一书《乡村振兴战略下传统村落文化旅游设计》许少辉瑞博士生辉少许——2023学生开学季许多少年辉光三农

10万单词例句表单词句子ACCESS\EXCEL数据库

原本我以为《3万5千英语句子英语例句大全ACCESS数据库》例句已经够多了&#xff0c;没想到今天遇到一个10万条英语单词例句的数据&#xff0c;非常适合与单词词典进行关联学习&#xff0c;例句多了单词的用法以及句子的掌握都更有效率。 截图下方有显示“共有记录数”&#xff…

Cesium 空间量算——面积量算

面积量算 需求分析 需求 对页面上所选内容进行面积计算 分析 其实&#xff0c;计算面积其实就是把一个面&#xff0c;拆分成一个一个的三角曲面计算然后相加得到&#xff0c;下面是计算的面积的代码 /** * description : 面积量算* author : Hukang* date : 2023-09-20 13:1…

Date类的学习笔记-超级详细

Date 的定义, 在开始研究这个之前我们首先要能够明白一点&#xff0c;这个 Date 其实本质上是一个对象&#xff0c;我们通过这个对象可以去构建变量&#xff0c;知道这个之后就可以开展后续的研究了 JDK 通用 Date 类的构造方法 测试 获取当前的时间 // 构造这个日期对象Date…

计算机毕设 opencv python 深度学习垃圾图像分类系统

文章目录 0 前言课题简介一、识别效果二、实现1.数据集2.实现原理和方法3.网络结构 最后 0 前言 &#x1f525; 这两年开始毕业设计和毕业答辩的要求和难度不断提升&#xff0c;传统的毕设题目缺少创新和亮点&#xff0c;往往达不到毕业答辩的要求&#xff0c;这两年不断有学弟…

Vue系列(三)之 基础语法【下篇】

一. 事件处理 在 Vue.js 中&#xff0c;v-on 指令被用于监听 DOM 事件&#xff0c;并在事件触发时执行相应的方法&#xff0c;这些方法就是事件处理器。v-on 指令有简写形式 &#xff0c;例如 click"handleClick" 会监听点击事件并执行 handleClick 方法。 事件处理…

MQ - 09 RabbitMQ的架构设计与实现

文章目录 导图概述RabbitMQ 系统架构协议和网络模块数据存储元数据存储 ---> 自带的分布式数据库 Mnesia消息数据存储 生产者和消费者HTTP 协议支持和管控操作RabbitMQ 从生产到消费的全过程总结 导图 概述 最基础的消息队列应该具备通信协议、网络模块、存储模块、生产者、…

socket() failed (24: Too many open files) while connecting to upstream, client

一、这个错误通常是因为文件句柄数目超过系统限制导致的。要解决这个问题&#xff0c;您可以尝试以下几个步骤&#xff1a; 调整系统文件句柄限制&#xff1a;您可以通过修改/etc/security/limits.conf文件中的nofile参数来增加系统文件句柄的最大数目。将nofile的值增加到更高…

zabbix监控平台部署(二)

目录 一、自定义监控 二、Nginx监控 三、监控mysql 四、钉钉告警 五、163邮箱报警 总结 zabbix5.0 一、自定义监控 zabbix-agent&#xff08;147&#xff09; agent端操作 vim /etc/zabbix/zabbix_agentd.conf 在配置未文件末尾添加 UserParametermemory_userd,free…

C++中 负数与String字符串的长度 string.size()作比较 输出错误

在刷题的时候&#xff0c;发现用 -1<t.size() 输出的是错误的值&#xff0c;如下&#xff0c;t“ABC”&#xff0c;但重新定义一个变量后又可以了&#xff0c;查阅检查后&#xff0c;发现string.size()返回的是一个无符号的整数&#xff0c;因此与有符号整数比较&#xff0c…

SpingBoot:整合Mybatis-plus+Druid+mysql

SpingBoot&#xff1a;整合Mybatis-plusDruid 一、特别说明二、创建springboot新工程三、配置3.1 配置pom.xml文件3.2 配置数据源和durid连接池3.3 编写拦截器配置类 四、自动生成代码五、测试六、附件-mysql数据库表 本文参考链接&#xff1a; [Java] Spring Boot 集成 MyBati…

免费、安全、可靠!一站式构建平台 ABS 介绍及实例演示 | 龙蜥技术

编者按&#xff1a;操作系统是一个大的软件集合&#xff0c;成百上千个软件之间有相互调用、相互依赖等各种复杂的关联关系&#xff0c;所以统一的软件包格式&#xff0c;能够更友好地管理、定义这些复杂关系。今天&#xff0c;龙蜥社区基础设施 Contributor 单凯伦带大家了解龙…

Python灰帽编程——网页信息爬取

文章目录 网页信息爬取1. 相关模块1.1 requests 模块1.1.1 模块中的请求方法1.1.2 请求方法中的参数1.1.3 响应对象中属性 1.2 RE 模块1.2.1 匹配单个字符1.2.2 匹配一组字符1.2.3 其他元字符1.2.4 核心函数 2. 网页信息爬取2.1 获取网页HTML 源代码2.2 提取图片地址2.3 下载图…

【机器学习】详解回归(Regression)

文章目录 是什么的问题案例说明 是什么的问题 回归分析&#xff08;Regression Analysis&#xff09; 是研究自变量与因变量之间数量变化关系的一种分析方法&#xff0c;它主要是通过因变量Y与影响它的自变量 X i &#xff08; i 1 , 2 , 3 … &#xff09; X_i&#xff08;i1…

鉴源论坛 · 观模丨基于应用程序编程接口(API)的自动化测试(下)

作者 | 黄杉 华东师范大学软件工程学院博士 苏亭 华东师范大学软件工程学院教授 版块 | 鉴源论坛 观模 社群 | 添加微信号“TICPShanghai”加入“上海控安51fusa安全社区” 上文“基于应用程序编程接口&#xff08;API&#xff09;的自动化测试&#xff08;上&#xff09;”…