1. import numpy as np
  2.  
  3. a = np.arange(8)
  4. print ('原始数组:')
  5. print (a)
  6. print ('\n')
  7.  
  8. b = a.reshape(4,2)
  9. print ('修改后的数组:')
  10. print (b)
  1. numpy.ndarray.flat 是一个数组元素迭代器
  2. import numpy as np
  3.  
  4. a = np.arange(9).reshape(3,3)
  5. print ('原始数组:')
  6. for row in a:
  7. print (row)
  8.  
  9. #对数组中每个元素都进行处理,可以使用flat属性,该属性是一个数组元素迭代器:
  10. print ('迭代后的数组:')
  11. for element in a.flat:
  12. print (element)

  1. import numpy as np
  2.  
  3. a = np.arange(8).reshape(2,4)
  4.  
  5. print ('原数组:')
  6. print (a)
  7. print ('\n')
  8. # 默认按行
  9.  
  10. print ('展开的数组:')
  11. print (a.flatten())
  12. print ('\n')
  13.  
  14. print ('以 F 风格顺序展开的数组:')
  15. print (a.flatten(order = 'F'))
  1. numpy.ravel() 展平的数组元素,顺序通常是"C风格",返回的是数组视图
  2. numpy.ravel(a, order='C')
  3. 参数说明:
  4. order'C' -- 按行,'F' -- 按列,'A' -- 原顺序,'K' -- 元素在内存中的出现顺序。
  1. import numpy as np
  2.  
  3. a = np.arange(8).reshape(2,4)
  4.  
  5. print ('原数组:')
  6. print (a)
  7. print ('\n')
  8.  
  9. print ('调用 ravel 函数之后:')
  10. print (a.ravel())
  11. print ('\n')
  12.  
  13. print ('以 F 风格顺序调用 ravel 函数之后:')
  14. print (a.ravel(order = 'F'))

  1. import numpy as np
  2.  
  3. a = np.arange(12).reshape(3,4)
  4.  
  5. print ('原数组:')
  6. print (a )
  7. print ('\n')
  8.  
  9. print ('对换数组:')
  10. print (np.transpose(a))
  1. import numpy as np
  2.  
  3. a = np.arange(12).reshape(3,4)
  4.  
  5. print ('原数组:')
  6. print (a)
  7. print ('\n')
  8.  
  9. print ('转置数组:')
  10. print (a.T)

  1. import numpy as np
  2.  
  3. # 创建了三维的 ndarray
  4. a = np.arange(8).reshape(2,2,2)
  5.  
  6. print ('原数组:')
  7. print (a)
  8. print ('\n')
  9. # 将轴 2 滚动到轴 0(宽度到深度)
  10.  
  11. print ('调用 rollaxis 函数:')
  12. print (np.rollaxis(a,2))
  13. # 将轴 0 滚动到轴 1:(宽度到高度)
  14. print ('\n')
  15.  
  16. print ('调用 rollaxis 函数:')
  17. print (np.rollaxis(a,2,1))

  1. import numpy as np
  2.  
  3. # 创建了三维的 ndarray
  4. a = np.arange(8).reshape(2,2,2)
  5.  
  6. print ('原数组:')
  7. print (a)
  8. print ('\n')
  9. # 现在交换轴 0(深度方向)到轴 2(宽度方向)
  10.  
  11. print ('调用 swapaxes 函数后的数组:')
  12. print (np.swapaxes(a, 2, 0))
  1. numpy.broadcast 用于模仿广播的对象,它返回一个对象,该对象封装了将一个数组广播到另一个数组的结果。
  2. 该函数使用两个数组作为输入参数
  1. import numpy as np
  2.  
  3. x = np.array([[1], [2], [3]])
  4. y = np.array([4, 5, 6])
  5.  
  6. # 对 y 广播 x
  7. b = np.broadcast(x,y)
  8. # 它拥有 iterator 属性,基于自身组件的迭代器元组
  9.  
  10. print ('对 y 广播 x:')
  11. r,c = b.iters
  12.  
  13. # Python3.x 为 next(context) ,Python2.x 为 context.next()
  14. print (next(r), next(c))
  15. print (next(r), next(c))
  16. print ('\n')
  17. # shape 属性返回广播对象的形状
  18.  
  19. print ('广播对象的形状:')
  20. print (b.shape)
  21. print ('\n')
  22. # 手动使用 broadcast 将 x 与 y 相加
  23. b = np.broadcast(x,y)
  24. c = np.empty(b.shape)
  25.  
  26. print ('手动使用 broadcast 将 x 与 y 相加:')
  27. print (c.shape)
  28. print ('\n')
  29. c.flat = [u + v for (u,v) in b]
  30.  
  31. print ('调用 flat 函数:')
  32. print (c)
  33. print ('\n')
  34. # 获得了和 NumPy 内建的广播支持相同的结果
  35.  
  36. print ('x 与 y 的和:')
  37. print (x + y)
  1. numpy.broadcast_to 函数将数组广播到新形状。它在原始数组上返回只读视图。 它通常不连续。 如果新形状不符合 NumPy 的广播规则,该函数可能会抛出ValueError
  1. import numpy as np
  2.  
  3. a = np.arange(4).reshape(1,4)
  4.  
  5. print ('原数组:')
  6. print (a)
  7. print ('\n')
  8.  
  9. print ('调用 broadcast_to 函数之后:')
  10. print (np.broadcast_to(a,(4,4)))

  1. import numpy as np
  2.  
  3. x = np.array(([1,2],[3,4]))
  4.  
  5. print ('数组 x:')
  6. print (x)
  7. print ('\n')
  8. y = np.expand_dims(x, axis = 0)
  9.  
  10. print ('数组 y:')
  11. print (y)
  12. print ('\n')
  13.  
  14. print ('数组 x 和 y 的形状:')
  15. print (x.shape, y.shape)
  16. print ('\n')
  17. # 在位置 1 插入轴
  18. y = np.expand_dims(x, axis = 1)
  19.  
  20. print ('在位置 1 插入轴之后的数组 y:')
  21. print (y)
  22. print ('\n')
  23.  
  24. print ('x.ndim 和 y.ndim:')
  25. print (x.ndim,y.ndim)
  26. print ('\n')
  27.  
  28. print ('x.shape 和 y.shape:')
  29. print (x.shape, y.shape)

  1. import numpy as np
  2.  
  3. x = np.arange(9).reshape(1,3,3)
  4.  
  5. print ('数组 x:')
  6. print (x)
  7. print ('\n')
  8. y = np.squeeze(x)
  9.  
  10. print ('数组 y:')
  11. print (y)
  12. print ('\n')
  13.  
  14. print ('数组 x 和 y 的形状:')
  15. print (x.shape, y.shape)

  1. import numpy as np
  2.  
  3. a = np.array([[1,2],[3,4]])
  4.  
  5. print ('第一个数组:')
  6. print (a)
  7. print ('\n')
  8. b = np.array([[5,6],[7,8]])
  9.  
  10. print ('第二个数组:')
  11. print (b)
  12. print ('\n')
  13. # 两个数组的维度相同
  14.  
  15. print ('沿轴 0 连接两个数组:')
  16. print (np.concatenate((a,b)))
  17. print ('\n')
  18.  
  19. print ('沿轴 1 连接两个数组:')
  20. print (np.concatenate((a,b),axis = 1))

  1. import numpy as np
  2.  
  3. a = np.array([[1,2],[3,4]])
  4.  
  5. print ('第一个数组:')
  6. print (a)
  7. print ('\n')
  8. b = np.array([[5,6],[7,8]])
  9.  
  10. print ('第二个数组:')
  11. print (b)
  12. print ('\n')
  13.  
  14. print ('沿轴 0 堆叠两个数组:')
  15. print (np.stack((a,b),0))
  16. print ('\n')
  17.  
  18. print ('沿轴 1 堆叠两个数组:')
  19. print (np.stack((a,b),1))
  1. numpy.hstack numpy.stack 函数的变体,它通过水平堆叠来生成数组。
  1. import numpy as np
  2.  
  3. a = np.array([[1,2],[3,4]])
  4.  
  5. print ('第一个数组:')
  6. print (a)
  7. print ('\n')
  8. b = np.array([[5,6],[7,8]])
  9.  
  10. print ('第二个数组:')
  11. print (b)
  12. print ('\n')
  13.  
  14. print ('水平堆叠:')
  15. c = np.hstack((a,b))
  16. print (c)
  17. print ('\n')
  1. numpy.vstack numpy.stack 函数的变体,它通过垂直堆叠来生成数组。
  1. import numpy as np
  2.  
  3. a = np.array([[1,2],[3,4]])
  4.  
  5. print ('第一个数组:')
  6. print (a)
  7. print ('\n')
  8. b = np.array([[5,6],[7,8]])
  9.  
  10. print ('第二个数组:')
  11. print (b)
  12. print ('\n')
  13.  
  14. print ('竖直堆叠:')
  15. c = np.vstack((a,b))
  16. print (c)

  1. import numpy as np
  2.  
  3. a = np.arange(9)
  4.  
  5. print ('第一个数组:')
  6. print (a)
  7. print ('\n')
  8.  
  9. print ('将数组分为三个大小相等的子数组:')
  10. b = np.split(a,3)
  11. print (b)
  12. print ('\n')
  13.  
  14. print ('将数组在一维数组中表明的位置分割:')
  15. b = np.split(a,[4,7])
  16. print (b)
  1. numpy.hsplit 函数用于水平分割数组,通过指定要返回的相同形状的数组数量来拆分原数组。
  1. import numpy as np
  2.  
  3. harr = np.floor(10 * np.random.random((2, 6)))
  4. print ('原array:')
  5. print(harr)
  6.  
  7. print ('拆分后:')
  8. print(np.hsplit(harr, 3))
  1. numpy.vsplit 沿着垂直轴分割,其分割方式与hsplit用法相同。
  1. import numpy as np
  2.  
  3. a = np.arange(16).reshape(4,4)
  4.  
  5. print ('第一个数组:')
  6. print (a)
  7. print ('\n')
  8.  
  9. print ('竖直分割:')
  10. b = np.vsplit(a,2)
  11. print (b)

  1. import numpy as np
  2.  
  3. a = np.array([[1,2,3],[4,5,6]])
  4.  
  5. print ('第一个数组:')
  6. print (a)
  7. print ('\n')
  8.  
  9. print ('第一个数组的形状:')
  10. print (a.shape)
  11. print ('\n')
  12. b = np.resize(a, (3,2))
  13.  
  14. print ('第二个数组:')
  15. print (b)
  16. print ('\n')
  17.  
  18. print ('第二个数组的形状:')
  19. print (b.shape)
  20. print ('\n')
  21. # 要注意 a 的第一行在 b 中重复出现,因为尺寸变大了
  22.  
  23. print ('修改第二个数组的大小:')
  24. b = np.resize(a,(3,3))
  25. print (b)
  1. numpy.append 函数在数组的末尾添加值。 追加操作会分配整个数组,并把原来的数组复制到新数组中。 此外,输入数组的维度必须匹配否则将生成ValueError
  2. append 函数返回的始终是一个一维数组。
  3. numpy.append(arr, values, axis=None)
  4. 参数说明:
  5. arr:输入数组
  6. values:要向arr添加的值,需要和arr形状相同(除了要添加的轴)
  7. axis:默认为 None。当axis无定义时,是横向加成,返回总是为一维数组!当axis有定义的时候,分别为01的时候。当axis有定义的时候,分别为01的时候(列数要相同)。当axis1时,数组是加在右边(行数要相同)。
  1. import numpy as np
  2.  
  3. a = np.array([[1,2,3],[4,5,6]])
  4.  
  5. print ('第一个数组:')
  6. print (a)
  7. print ('\n')
  8.  
  9. print ('向数组添加元素:')
  10. print (np.append(a, [7,8,9]))
  11. print ('\n')
  12.  
  13. print ('沿轴 0 添加元素:')
  14. print (np.append(a, [[7,8,9]],axis = 0))
  15. print ('\n')
  16.  
  17. print ('沿轴 1 添加元素:')
  18. print (np.append(a, [[5,5,5],[7,8,9]],axis = 1))
  1. numpy.insert 函数在给定索引之前,沿给定轴在输入数组中插入值。
  2. 如果值的类型转换为要插入,则它与输入数组不同。 插入没有原地的,函数会返回一个新数组。 此外,如果未提供轴,则输入数组会被展开。
  3. numpy.insert(arr, obj, values, axis)
  4. 参数说明:
  5. arr:输入数组
  6. obj:在其之前插入值的索引
  7. values:要插入的值
  8. axis:沿着它插入的轴,如果未提供,则输入数组会被展开
  1. import numpy as np
  2.  
  3. a = np.array([[1,2],[3,4],[5,6]])
  4.  
  5. print ('第一个数组:')
  6. print (a)
  7. print ('\n')
  8.  
  9. print ('未传递 Axis 参数。 在插入之前输入数组会被展开。')
  10. print (np.insert(a,3,[11,12]))
  11. print ('\n')
  12. print ('传递了 Axis 参数。 会广播值数组来配输入数组。')
  13.  
  14. print ('沿轴 0 广播:')
  15. print (np.insert(a,1,[11],axis = 0))
  16. print ('\n')
  17.  
  18. print ('沿轴 1 广播:')
  19. print (np.insert(a,1,11,axis = 1))

  1. import numpy as np
  2.  
  3. a = np.arange(12).reshape(3,4)
  4.  
  5. print ('第一个数组:')
  6. print (a)
  7. print ('\n')
  8.  
  9. print ('未传递 Axis 参数。 在插入之前输入数组会被展开。')
  10. print (np.delete(a,5))
  11. print ('\n')
  12.  
  13. print ('删除第二列:')
  14. print (np.delete(a,1,axis = 1))
  15. print ('\n')
  16.  
  17. print ('包含从数组中删除的替代值的切片:')
  18. a = np.array([1,2,3,4,5,6,7,8,9,10])
  19. print (np.delete(a, np.s_[::2]))

  1. import numpy as np
  2.  
  3. a = np.array([5,2,6,2,7,5,6,8,2,9])
  4.  
  5. print ('第一个数组:')
  6. print (a)
  7. print ('\n')
  8.  
  9. print ('第一个数组的去重值:')
  10. u = np.unique(a)
  11. print (u)
  12. print ('\n')
  13.  
  14. print ('去重数组的索引数组:')
  15. u,indices = np.unique(a, return_index = True)
  16. print (indices)
  17. print ('\n')
  18.  
  19. print ('我们可以看到每个和原数组下标对应的数值:')
  20. print (a)
  21. print ('\n')
  22.  
  23. print ('去重数组的下标:')
  24. u,indices = np.unique(a,return_inverse = True)
  25. print (u)
  26. print ('\n')
  27.  
  28. print ('下标为:')
  29. print (indices)
  30. print ('\n')
  31.  
  32. print ('使用下标重构原数组:')
  33. print (u[indices])
  34. print ('\n')
  35.  
  36. print ('返回去重元素的重复数量:')
  37. u,indices = np.unique(a,return_counts = True)
  38. print (u)
  39. print (indices)

吴裕雄--天生自然Numpy库学习笔记:Numpy 数组操作的更多相关文章

  1. 吴裕雄--天生自然C++语言学习笔记:C++ 标准库

    C++ 标准库可以分为两部分: 标准函数库: 这个库是由通用的.独立的.不属于任何类的函数组成的.函数库继承自 C 语言. 面向对象类库: 这个库是类及其相关函数的集合. C++ 标准库包含了所有的 ...

  2. 吴裕雄--天生自然C++语言学习笔记:C++ STL 教程

    C++ STL(标准模板库)是一套功能强大的 C++ 模板类,提供了通用的模板类和函数,这些模板类和函数可以实现多种流行和常用的算法和数据结构,如向量.链表.队列.栈. C++ 标准模板库的核心包括以 ...

  3. 吴裕雄--天生自然C++语言学习笔记:C++ Web 编程

    什么是 CGI? 公共网关接口(CGI),是一套标准,定义了信息是如何在 Web 服务器和客户端脚本之间进行交换的. CGI 规范目前是由 NCSA 维护的,NCSA 定义 CGI 如下: 公共网关接 ...

  4. 吴裕雄--天生自然C++语言学习笔记:C++ 多线程

    多线程是多任务处理的一种特殊形式,多任务处理允许让电脑同时运行两个或两个以上的程序.一般情况下,两种类型的多任务处理:基于进程和基于线程. 基于进程的多任务处理是程序的并发执行. 基于线程的多任务处理 ...

  5. 吴裕雄--天生自然C++语言学习笔记:C++ 信号处理

    信号是由操作系统传给进程的中断,会提早终止一个程序.在 UNIX.LINUX.Mac OS X 或 Windows 系统上,可以通过按 Ctrl+C 产生中断. 有些信号不能被程序捕获,但是下表所列信 ...

  6. 吴裕雄--天生自然C++语言学习笔记:C++ 模板

    模板是泛型编程的基础,泛型编程即以一种独立于任何特定类型的方式编写代码. 模板是创建泛型类或函数的蓝图或公式.库容器,比如迭代器和算法,都是泛型编程的例子,它们都使用了模板的概念. 每个容器都有一个单 ...

  7. 吴裕雄--天生自然C++语言学习笔记:C++ 命名空间

    假设这样一种情况,当一个班上有两个名叫 Zara 的学生时,为了明确区分它们,在使用名字之外,不得不使用一些额外的信息,比如他们的家庭住址,或者他们父母的名字等等. 同样的情况也出现在 C++ 应用程 ...

  8. 吴裕雄--天生自然C++语言学习笔记:C++ 文件和流

    如何从文件读取流和向文件写入流.这就需要用到 C++ 中另一个标准库 fstream,它定义了三个新的数据类型: ofstream 该数据类型表示输出文件流,用于创建文件并向文件写入信息. ifstr ...

  9. 吴裕雄--天生自然C++语言学习笔记:C++ 数据抽象

    数据抽象是指,只向外界提供关键信息,并隐藏其后台的实现细节,即只表现必要的信息而不呈现细节. 数据抽象是一种依赖于接口和实现分离的编程(设计)技术. 它们向外界提供了大量用于操作对象数据的公共方法,也 ...

  10. 吴裕雄--天生自然C++语言学习笔记:C++ 日期 & 时间

    C++ 标准库没有提供所谓的日期类型.C++ 继承了 C 语言用于日期和时间操作的结构和函数.为了使用日期和时间相关的函数和结构,需要在 C++ 程序中引用 <ctime> 头文件. 有四 ...

随机推荐

  1. 2.springboot------微服务

    什么是微服务? 微服务是一种架构风格,它要求我们在开发一个应用的时候,这个应用必须构建成一系列小服务的组合:可以通过http的方式进行互通.要说微服务架构,先得说说过去我们的单体应用架构. 单体应用架 ...

  2. Iris配置

    package main import ( "github.com/kataras/iris" "os" "encoding/json" & ...

  3. ffmpeg-- audio decoder

    测试代码来源于:http://ffmpeg.org/doxygen/trunk/decode_audio_8c-example.html /* * Copyright (c) 2001 Fabrice ...

  4. (转)Java中的String与常量池

    Java中的String与常量池 转自:http://developer.51cto.com/art/201106/266454.htm string是java中的字符串.String类是不可变的,对 ...

  5. Android输入法挤乱布局问题

    今天做布局的时候 嵌套的TbaleLayout里面有三行  但是准备输入的时候输入法自动将整个activity布局全部往上挤 导致输入框变小甚至消失  弄的很是郁闷 在网上查了之后  发现有些人是因为 ...

  6. vue 项目太大, 导致 javascript heap out of memory

    原因: node 环境, 对单个进程的内存是有限制的, 但是现在前端项目太大, 所以我们需要根据当前机器环境, 手动加大node的内存限制 安装包 npm i increase-memory-limi ...

  7. IIS的部署(二)------虚拟目录的使用

    IIS的虚拟目录 一个站点的网页的存储位置目录是固定的,而且结构和物理保存网页的磁盘路径相同.例如:默认网页的存储位置是c:\inetpub\wwwroot,当访问localhost即访问c:\ine ...

  8. 吴裕雄 python 机器学习——人工神经网络与原始感知机模型

    import numpy as np from matplotlib import pyplot as plt from mpl_toolkits.mplot3d import Axes3D from ...

  9. 利用mnist训练集生成的caffemodel对mnist测试集与自己手写的数字进行测试

    从一到二:利用mnist训练集生成的caffemodel对mnist测试集与自己手写的数字进行测试 通过从零到一的教程,我们已经得到了通过mnist训练集生成的caffemodel,主要包含下面四个文 ...

  10. [LeetCode]1.Two Sum 两数之和&&第一次刷题感想

    ---恢复内容开始--- 参考博客: https://www.cnblogs.com/grandyang/p/4130379.html https://blog.csdn.net/weixin_387 ...