numpy的基本操作

简介: numpy的基本操作

1.常用方法创建array


print(np.array([1, 2, 3], dtype="f4"))# 32位浮点型


print(np.array([1.5, 2.2, 3]))# 默认浮点型


print(np.array([1, 2, 3, 4, 5], ndmin=3))# 3维数组


print(np.array([range(i, i + 5) for i in [1, 2, 3]]))#


print(np.zeros(shape=[5, 5], dtype="i4"))# 5x5的0数组


print(np.ones(shape=[5, 5], dtype="i4"))# 5x5的1数组


print(np.array(["1.1", "2.2", "3.3"], dtype="S").astype("f4"))#


print(np.array(["1.1", "2.2", "3.3"], dtype="S").astype("f4"))# 字符串数组转为浮点型数组


# 所有非零元素的索引

a=np.nonzero(np.array([1, 0, 2, 3, 0, 4]))#

print(a)#(array([0, 2, 3, 5], dtype=int64),)

print(a[0])# [0 2 3 5]

print(np.full(shape=[5, 5], fill_value=1.5, dtype=np.float_))# 5x5的1.5数组

print(np.eye(10))# 10x10的单位阵

# 数组元素为随机值,因为它们未初始化

print(np.empty(shape=(5, 5)))# 5x5的未初始化数组

print(np.linspace(1, 10, 5))# 返回num个等间距的样本

 

 

 

print(np.random.random((5, 5)))# 随机生成5行5列

# 生成[0, 10) 且 3行3列的随机数

# 生成的数据包括起始值和结束值,但不包括结束值本身。

print(np.random.randint(0, 10, (3, 3)))# 3x3的随机整数数组, 值在[0, 10)

print(np.random.normal(0, 1, (3, 3)))# 3x3的正态分布随机数, 均值为0, 方差为1

print(np.array([1, 2, 3]).itemsize)# 元素字节大小, 32位=4字节

2. Numpy 索引和切片

在Python中,切片(slice)是对序列型对象(如list, string, tuple)的一种高级索引方法。

普通索引只取出序列中一个下标对应的元素,而切片取出序列中一个范围对应的元素

2.1普通索引

一维的索引

a1 = np.array([1, 2, 3, 4])

print(a1)

print(a1[0])

print(a1[2])

二维的索引

a2 = np.array([

[1, 2, 3],

[4, 5, 6],

[7, 8, 9]

])

print(a2[2])

print(a2[2, 1])

print(a2[:, 2])# 第2列元素,行索引省略表示所有行

a3 = np.array([

   [[10, 11, 12], [13, 14, 15], [16, 17, 18]],

   [[20, 21, 22], [23, 24, 25], [26, 27, 28]],

   [[30, 31, 32], [33, 34, 35], [36, 37, 38]]

])


# 打印数组 a3 的形状

print(a3.shape)  

# 打印 a3 的第三层(索引为 2)

print(a3[2])  

# 打印 a3 第三层的第一层(索引为 2,0)

print(a3[2, 0])  

# 打印 a3 第三层第一层的第二个元素(索引为 2,0,1)

print(a3[2, 0, 1])  

# 打印 a3 所有层的第二层的第三个元素(索引为 :,1,2)

print(a3[:, 1, 2])  

# 打印 a3 第二层的第三层(索引为 1,2)

print(a3[1, 2])  

# 打印 a3 第一层的所有元素(索引为 0,:)

print(a3[0, :])  

# 打印 a3 第一层的所有第二层元素(索引为 0,:,1)

print(a3[0, :, 1])  

# 打印 a3 所有层的第二层(索引为 :,1)

print(a3[:, 1])  

# 打印 a3 所有层的第二层的第一个元素(索引为 :,1,0)

print(a3[:, 1, 0])  

# 打印 a3 所有层的第二层和第三层的第一个元素(索引为 :,1:3,0)

print(a3[:, 1:3, 0])  

# 打印 a3 所有层的前两层的前两层(索引为 :,:2,:2)

print(a3[:, :2, :2])  

# 打印 a3 第二层的第二层和第三层的第二个元素(索引为 1:2,1:3,1)

print(a3[1:2, 1:3, 1])  

print(a3[:, 0, 1])  # 打印所有层的第一层的第二个元素

print(a3[:, ::2, 1])  # 打印所有层的隔一个元素的层的第二层元素

print(a3[:, [0, 2], [0, 1]])  # 以特定索引组合打印元素

2.2索引可以是array数组

data = np.array([1, 2, 3, 4, 5, 6, 7, 8, 9])

mask1 = np.array([True, False, True, False, True, False, True, False, True],dtype=np.bool_)

index = np.array([1, 0, 1, 0, 1, 0, 1, 0, 1], dtype="i1")

print(data[mask1])# 索引为True的元素

# index表示索引 将data对应的索引选择出来

print(data[index])# 索引为1,0,1,0的元素

.data = np.array([1, 2, 3, 4, 5, 6, 7, 8, 9])

index = np.array([2, 4, 1, 0], dtype="i1")

print(data[index])# 索引为2,4,1,0的元素

2.3高级索引

arr = np.array([

   [1, 2, 3],

   [4, 5, 6],

   [7, 8, 9]])

# 使用整数数组索引选择元素

indices = np.array([0, 2])

result = arr[:, indices]# 选择第0列和第2列,即第0行和第2行

#result = arr[:, [0, 2]]#与上一行等价

print(result)

相关文章
|
5月前
|
程序员 开发工具 索引
图解Python numpy基本操作
图解Python numpy基本操作
|
5月前
|
搜索推荐 索引 Python
【科学计算包NumPy】NumPy数组的基本操作
【科学计算包NumPy】NumPy数组的基本操作
65 3
|
5月前
|
机器学习/深度学习 数据挖掘 Python
NumPy的基本操作(Python)
NumPy的基本操作(Python)
54 4
|
Python
CV5 numpy入门及图像的基本操作
复制法,即复制最边缘的像素。
78 0
|
数据挖掘 Python
【Python数据分析 - 5】:Numpy-数组的基本操作
【Python数据分析 - 5】:Numpy-数组的基本操作
101 0
【Python数据分析 - 5】:Numpy-数组的基本操作
|
机器学习/深度学习 数据挖掘 BI
NumPy数据分析基础:ndarray数组运算基本操作及切片索引迭代
NumPy数据分析基础:ndarray数组运算基本操作及切片索引迭代
139 0
NumPy数据分析基础:ndarray数组运算基本操作及切片索引迭代
|
索引 Python
05 numpy 基本操作
=== 为三个学生的三门课程成绩建模 === 姓名/成绩 语文 数学 英语 物理 Tom 90 100 110 89 Ali 80 100 33 99 Li 89 99 33 93 stu_info = np.
1010 0
|
12天前
|
机器学习/深度学习 数据处理 Python
从NumPy到Pandas:轻松转换Python数值库与数据处理利器
从NumPy到Pandas:轻松转换Python数值库与数据处理利器
33 0
|
2月前
|
机器学习/深度学习 数据处理 计算机视觉
NumPy实践宝典:Python高手教你如何轻松玩转数据处理!
【8月更文挑战第22天】NumPy是Python科学计算的核心库,专长于大型数组与矩阵运算,并提供了丰富的数学函数。首先需安装NumPy (`pip install numpy`)。之后可通过创建数组、索引与切片、执行数学与逻辑运算、变换数组形状及类型、计算统计量和进行矩阵运算等操作来实践学习。NumPy的应用范围广泛,从基础的数据处理到图像处理都能胜任,是数据科学领域的必备工具。
48 0
|
14天前
|
机器学习/深度学习 算法 数据可视化
8种数值变量的特征工程技术:利用Sklearn、Numpy和Python将数值转化为预测模型的有效特征
特征工程是机器学习流程中的关键步骤,通过将原始数据转换为更具意义的特征,增强模型对数据关系的理解能力。本文重点介绍处理数值变量的高级特征工程技术,包括归一化、多项式特征、FunctionTransformer、KBinsDiscretizer、对数变换、PowerTransformer、QuantileTransformer和PCA,旨在提升模型性能。这些技术能够揭示数据中的潜在模式、优化变量表示,并应对数据分布和内在特性带来的挑战,从而提高模型的稳健性和泛化能力。每种技术都有其独特优势,适用于不同类型的数据和问题。通过实验和验证选择最适合的变换方法至关重要。
19 5
8种数值变量的特征工程技术:利用Sklearn、Numpy和Python将数值转化为预测模型的有效特征

相关实验场景

更多