27个新手级Numpy操作(numpy视频教程)
ztj100 2024-11-08 15:06 17 浏览 0 评论
本文介绍初学者应当掌握的27个numpy操作。
1、将列表转换为ndarray
使用np.array()将Python列表转换为Numpy数组:
numpy_array = np.array(list_to_convert)
2、使用np.newaxis和np.reshape
np.newaxis用来创建大小为1的新维度。例如:
a = [1,2,3,4,5] # 列表 a_numpy = np.array(a)
如果你打印a_numpy.shape,就会得到 (5,)。为了将其转换为行向量或 列向量,可以这么做:
row_vector = a_numpy[:,np.newaxis] ####shape: (5,1) col_vector = a_numpy[np.newaxis,:] ####shape: (1,5)
类似的,np.reshape可以用来重设任意数组的形状,例如:
a = range(0,15) # 列表:从0到14 b = a.reshape(3,5)
现在b就是这样:
[[0,1,2,3,4], [5,6,7,8,9], [10,11,12,13,14], [15,16,17,18,19]]
3、将任意数据类型转换为numpy数组
使用np.asarray()可以将任意数据类型转换为一个Numpy数组。例如: a = [(1,2), [3,4,(5)], (6,7,8)] b = np.asarray(a) 现在b就是numpy数组了: array([(1, 2), list([3, 4, (5, 6)]), (6, 7, 8)], dtype=object)
4、创建一个N维全零数组
使用np.zeros()创建一个N维numpy数组,其成员全部都是0。
a = np.zeros(shape,dtype=type_of_zeros)
type_of_zeros可以是整型或浮点型,例如:
a = np.zeros((3,4), dtype = np.float16)
5、创建一个N维全1数组
使用np.ones()可以创建一个N维Numpy数组,其成员全部都是1。
a = np.ones((3,4), dtype=np.int32)
6、np.full 和 np.empty
np.full()用来创建使用单一指定值填充的Numpy数组:
np.full(shape_as_tuple,value_to_fill,dtype=type_you_want)
例如:
a = np.full((2,3),1,dtype=np.float16)
现在a的值如下:
array([[1., 1., 1.], [1., 1., 1.]], dtype=float16)
np.empty()用来创建使用随机值填充的Numpy数组。
np.empty(shape_as_tuple,dtype=int)
例如:
a = np.empty((2,2),dtype=np.int16)
现在a的值如下:
array([[25824, 25701], [ 2606, 8224]], dtype=int16)
所有的成员都是随机数。
7、np.arrange和np.linspace
np.arrange()和np.linspace()都可以用来创建一个等差的numpy数组,相邻成员 值差值保持固定不变。
np.arange(start=where_to_start,stop=where_to_stop,step=step_size) np.linspace(start,stop,num=50,endpoint=bool_value,retstep=bool_value)
例如,下面的代码创建一个包含5个成员的numpy数组,从1开始到2截止:
np.linspace(1,2,num=5,endpoint=False,retstep=True)
得到的结果如下,linspace返回一个元组,第一个成员是numpy数组,第二个成员是值间隔:
(array([1. , 1.2, 1.4, 1.6, 1.8]), 0.2)
8、查看Numpy数组的形状
使用shape属性查看numpy数组对象的数据形状:
array.shape
9、了解Numpy数组的维度数量
使用ndim属性查看Numpy数组的维度数量:
x = np.array([1,2,3]) print(x.ndim) # 输出: 1
10、获取Numpy数组成员数量
使用size属性获取Numpy数组的成员数量:
x = np.ones((3,2,4),dtype=np.int16) print(x.size) # 输出:24
11、获取Numpy数组的内存占用情况
使用nbytes属性获取Numpy数组的内存占用情况。例如:
x = np.ones((3,2,4),dtype=np.int16) print(x.nbytes) # 输出:48
上面的x变量有24个成员,每个成员为int16类型即占用两个字节, 因此总内存占用字节数为:24*2 = 48。
12、查看Numpy数组成员的数据类型
使用dtype属性查看Numpy数组成员的数据类型。例如:
x = np.ones((2,3), dtype=np.int16) print(x.dtype) # 输出:dtype('int16')
13、克隆一个Numpy数组
使用np.copy()创建一个Numpy数组的副本。
y = np.array([[1,3],[5,6]]) x = np.copy(y)
14、Numpy数组转置
使用T属性获取一个Numpy数组的行列转置:
x = [[1,2],[3,4]]
x看起来是这样:
1 2 3 4
x.T看起来是这样:
1 3 2 4
15、拉平N维Numpy数组为一维
使用np.reshape()和np.ravel()。
例如:
x= np.array([[1,2,3],[4,5,6]]) y = x.reshape(-1)
y现在是[1,2,3,4,5,6]。
使用np.ravel()也可以达到同样的效果:
x = np.array([[1, 2, 3], [4, 5, 6]]) y = x.ravel() # [1,2,3,4,5,6]
16、改变或交换N维Numpy数组的轴
使用np.moveaxis()和np.swapaxes()方法。
np.moveaxis(x,axes_to_move_as_list, destination_axes_as_list)
例如:
x = np.ones((3,4,5)) y = x.moveaxis([1,2],[0,-2]) # 1 -> 0 , 2 -> -2
上面的代码将x的第1轴变成第0轴,第2轴变成倒数第2轴,因此最终 的数组形状为:(4,5,3)。
上述变换不是本地进行的,因此别忘了另存一个变量。
np.swapaxes()可以交换指定的数据轴,例如:
x = np.array([[1,2],[3,4]]) y = np.swapaxes(x,0,1) # 0 -> 1
x本来是:
1 2 3 4
经过0轴和1轴的交换,y现在是:
1 3 2 4
下面的代码将形状(3,4,5)的数组转换为(5,4,3):
x= np.ones((3,4,5)) y = np.swapaxes(0,2) print(y.shape) # (5,4,3)
17、将Numpy数组转换为列表
使用tolist()方法将Numpy数组转换为列表对象:
x = np.array([[3,4,5,9],[2,6,8,0]]) y = x.tolist()
现在的y是:
[[3, 4, 5, 9], [2, 6, 8, 0]]
18、修改Numpy数组成员的数据类型
使用astype()方法修改Numpy数组成员的数据类型。
x = np.array([0,1,2.0,3.0,4.2],dtype=np.float32)
转换为 int16:
x.astype(np.int16)
x现在是这样:
array([0, 1, 2, 3, 4], dtype=int16)
转换为bool:
x.astype(np.bool)
x现在是这样:
array([False, True, True, True, True])
19、获取非零成员的索引
使用nonzero()方法获取Numpy数组中非零成员的索引。
x = np.array([0,1,2.0,3.0,4.2],dtype=np.float32) y = x.nonzero() # y: (array([1, 2, 3, 4]),)
注意上面的x形状为(5,),因此得到的索引只有第1项。
x = np.array([[0,1],[3,5]]) y = x.nonzero() # y:(array([0, 1, 1]), array([1, 0, 1]))
20、Numpy数组排序
使用sort()方法对Numpy数组进行排序。
x = np.array([[4,3],[3,2]) x is 4 3 3 2 x.sort(axis=1) #sort each row 3 4 2 3 x.sort(axis=0) #sort each col 3 2 4 3
21、Numpy数组的值比较
通过将Numpy数组与某个值比较可以得到一个布尔类型的新数组。例如:
x = np.array([[0,1],[2,3]]) y = x==1
得到的y如下:
array([[False, True], [False, False]])
22、两个Numpy数组乘积
使用np.matmul()计算两个Numpy数组的矩阵乘积:
a = np.eye(2) #identity matrix of size 2 a 1 0 0 1 b = np.array([[1,2],[3,4]]) b 1 2 3 4 np.matmul(a,b) will give 1 2 3 4
23、计算两个Numpy数组的点乘
使用np.dot()计算两个Numpy数组的点乘:
a = np.array([[1,2,3],[4,8,16]]) a: 1 2 3 4 8 16 b = np.array([5,6,11]).reshape(-1,1) b: 5 6 11 np.dot(a,b) produces 38 160
24、计算两个Numpy向量的叉乘
使用np.cross()计算两个Numpy向量的叉乘
x = [1,2,3] y = [4,5,6] z = np.cross(x, y)
z的内容为:
array([-3, 6, -3])
25、计算Numpy数组的梯度
使用np.gradient()计算一个Numpy数组的梯度:
x = np.array([5, 10, 14, 17, 19, 26], dtype=np.float16) y = np.gradient(x)
y:
array([5. , 4.5, 3.5, 2.5, 4.5, 7. ], dtype=float16)
26、Numpy数组切片
要切片单个成员:
x[r][c] # r,c表示成员的行、列 要切片多个成员。假设x为:
2 4 9 3 1 5 7 8 0
如果希望切片2,4和7,8,那么:
x[[0,0,2,2],[0,1,0,1]]
就可以得到:
array([2, 4, 7, 8])
如果要切片的某一维度是连续的,那更容易:
x[[0,2],0:2]
得到结果:
array([[2, 4], [7, 8]]) `
27、Numpy数组的广播
对于新手有点复杂,本文删除该内容,另专文介绍。
原文来自汇智网:http://blog.hubwiz.com/2019/09/29/27-numpy-ops-for-beginner/
相关推荐
- 如何将数据仓库迁移到阿里云 AnalyticDB for PostgreSQL
-
阿里云AnalyticDBforPostgreSQL(以下简称ADBPG,即原HybridDBforPostgreSQL)为基于PostgreSQL内核的MPP架构的实时数据仓库服务,可以...
- Python数据分析:探索性分析
-
写在前面如果你忘记了前面的文章,可以看看加深印象:Python数据处理...
- C++基础语法梳理:算法丨十大排序算法(二)
-
本期是C++基础语法分享的第十六节,今天给大家来梳理一下十大排序算法后五个!归并排序...
- C 语言的标准库有哪些
-
C语言的标准库并不是一个单一的实体,而是由一系列头文件(headerfiles)组成的集合。每个头文件声明了一组相关的函数、宏、类型和常量。程序员通过在代码中使用#include<...
- [深度学习] ncnn安装和调用基础教程
-
1介绍ncnn是腾讯开发的一个为手机端极致优化的高性能神经网络前向计算框架,无第三方依赖,跨平台,但是通常都需要protobuf和opencv。ncnn目前已在腾讯多款应用中使用,如QQ,Qzon...
- 用rust实现经典的冒泡排序和快速排序
-
1.假设待排序数组如下letmutarr=[5,3,8,4,2,7,1];...
- ncnn+PPYOLOv2首次结合!全网最详细代码解读来了
-
编辑:好困LRS【新智元导读】今天给大家安利一个宝藏仓库miemiedetection,该仓库集合了PPYOLO、PPYOLOv2、PPYOLOE三个算法pytorch实现三合一,其中的PPYOL...
- C++特性使用建议
-
1.引用参数使用引用替代指针且所有不变的引用参数必须加上const。在C语言中,如果函数需要修改变量的值,参数必须为指针,如...
- Qt4/5升级到Qt6吐血经验总结V202308
-
00:直观总结增加了很多轮子,同时原有模块拆分的也更细致,估计为了方便拓展个管理。把一些过度封装的东西移除了(比如同样的功能有多个函数),保证了只有一个函数执行该功能。把一些Qt5中兼容Qt4的方法废...
- 到底什么是C++11新特性,请看下文
-
C++11是一个比较大的更新,引入了很多新特性,以下是对这些特性的详细解释,帮助您快速理解C++11的内容1.自动类型推导(auto和decltype)...
- 掌握C++11这些特性,代码简洁性、安全性和性能轻松跃升!
-
C++11(又称C++0x)是C++编程语言的一次重大更新,引入了许多新特性,显著提升了代码简洁性、安全性和性能。以下是主要特性的分类介绍及示例:一、核心语言特性1.自动类型推导(auto)编译器自...
- 经典算法——凸包算法
-
凸包算法(ConvexHull)一、概念与问题描述凸包是指在平面上给定一组点,找到包含这些点的最小面积或最小周长的凸多边形。这个多边形没有任何内凹部分,即从一个多边形内的任意一点画一条线到多边形边界...
- 一起学习c++11——c++11中的新增的容器
-
c++11新增的容器1:array当时的初衷是希望提供一个在栈上分配的,定长数组,而且可以使用stl中的模板算法。array的用法如下:#include<string>#includ...
- C++ 编程中的一些最佳实践
-
1.遵循代码简洁原则尽量避免冗余代码,通过模块化设计、清晰的命名和良好的结构,让代码更易于阅读和维护...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- node卸载 (33)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- exceptionininitializererror (33)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)