欢迎关注公众号【Python开发实战】, 获取更多内容!

工具-numpy

numpy是使用Python进行数据科学的基础库。numpy以一个强大的N维数组对象为中心,它还包含有用的线性代数,傅里叶变换和随机数函数。

一维ndarray

导入numpy

  1. import numpy as np

一维ndarray的访问和常规的Python数组类似。

  1. a = np.array([1, 5, 3, 19, 13, 7, 3])
  2. a[3]

输出:

  1. 19
  1. a[2:5]

输出:

  1. array([ 3, 19, 13])
  1. a[2:-1]

输出:

  1. array([ 3, 19, 13, 7])
  1. a[:2]

输出:

  1. array([1, 5])
  1. a[2::2]

输出:

  1. array([ 3, 13, 3])
  1. a[::-1]

输出:

  1. array([ 3, 7, 13, 19, 3, 5, 1])

当然,也可以修改ndarray的元素。

  1. a[3] = 999
  2. a

输出:

  1. array([ 1, 5, 3, 999, 13, 7, 3])

也可以修改一个ndarray的切片。

  1. a[2:5] = [997, 998, 999]
  2. a

输出:

  1. array([ 1, 5, 997, 998, 999, 7, 3])

与常规数组的区别

与常规Python数组相反,如果将一个值赋给一个ndarray切片,则整个切片里的元素都会被赋值为这个值,这是由于广播机制。

  1. a[2:5] = -1
  2. a

输出:

  1. array([ 1, 5, -1, -1, -1, 7, 3])

另外,不能以这种方式增加或缩小ndarray。

  1. try:
  2. a[2:5] = [1, 2, 3, 4, 5, 6]
  3. except ValueError as e:
  4. print(e)

输出:

  1. cannot copy sequence with size 6 to array axis with dimension 3

也不能删除元素。

  1. try:
  2. del a[2:5]
  3. except ValueError as e:
  4. print(e)

输出:

  1. cannot delete array elements

值得注意的是,ndarray切片实际上是同一数据缓冲区上的视图。这就意味着,如果创建一个切片并对其进行修改,也将会修改原始的ndarray。

  1. a_slice = a[2:6]
  2. a_slice[1] = 1000
  3. a # 原始ndarray也被修改!

输出:

  1. array([ 1, 5, -1, 1000, -1, 7, 3])
  1. a[3] = 2000
  2. a_slice # 修改切片也会修改原始ndarray!

输出:

  1. array([ -1, 2000, -1, 7])

如果想复制ndarray的数据,需要使用copy方法。

  1. another_slice = a[2:6].copy()
  2. another_slice[1] = 3000
  3. a # 原始ndarray不变

输出:

  1. array([ 1, 5, -1, 2000, -1, 7, 3])
  1. a[3] = 4000
  2. another_slice # 修改原始ndarray不会影响切片的副本

输出:

  1. array([ -1, 3000, -1, 7])

多维ndarray

多维ndarray的访问也是类似的方式,通过为每个轴提供索引或切片的形式,不同轴之间的索引或切片用逗号分隔。

  1. b = np.arange(48).reshape(4, 12)
  2. b

输出:

  1. array([[ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11],
  2. [12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23],
  3. [24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35],
  4. [36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47]])
  1. b[1, 2] # 第1行 第2列

输出:

  1. 14
  1. b[1, :] # 第1行的所有列元素

输出:

  1. array([12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23])
  1. b[:, 1] # 第1列的所有行元素

输出:

  1. array([ 1, 13, 25, 37])

注意!注意下面两个结果间的细微差别。

  1. b[1, :]

输出:

  1. array([12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23])
  1. b[1:2, :]

输出:

  1. array([[12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23]])

第一个结果是将第1行作为一个形状为(12,)的一维数组返回,第二个结果是将第1行作为形状为(1,12)的二维数组返回。

花式索引

还可以指定感兴趣的索引列表,被称为花式索引。

  1. b[(0, 2), 2:5]

输出:

  1. array([[ 2, 3, 4],
  2. [26, 27, 28]])
  1. b[:, (-1, 2, -1)]

输出:

  1. array([[11, 2, 11],
  2. [23, 14, 23],
  3. [35, 26, 35],
  4. [47, 38, 47]])

如果提供多个索引数组,将会得到一个一维ndarray,其中包含指定坐标处元素的值。

  1. b[(-1, 2, -1, 2), (5, 9, 1, 9)] # 返回由b[-1, 5] b[2, 9] b[-1, 1] b[2, 9]组成的一维数组

输出:

  1. array([41, 33, 37, 33])

更高维数组

对于更高维数组,上面的索引方式也满足。

  1. c = b.reshape(4, 2, 6)
  2. c

输出:

  1. array([[[ 0, 1, 2, 3, 4, 5],
  2. [ 6, 7, 8, 9, 10, 11]],
  3. [[12, 13, 14, 15, 16, 17],
  4. [18, 19, 20, 21, 22, 23]],
  5. [[24, 25, 26, 27, 28, 29],
  6. [30, 31, 32, 33, 34, 35]],
  7. [[36, 37, 38, 39, 40, 41],
  8. [42, 43, 44, 45, 46, 47]]])
  1. c[2, 1, 4]

输出:

  1. 34
  1. c[2, :, 3]

输出:

  1. array([27, 33])

如果省略某些轴的坐标,则会返回这些轴中的所有元素。

  1. c[2, 1]

输出:

  1. array([30, 31, 32, 33, 34, 35])

省略号

也可以使用一个省略号...,表示将所有未指定的轴的元素全部包含在内。

  1. c[2, ...] # 相当于c[2, :, :]

输出:

  1. array([[24, 25, 26, 27, 28, 29],
  2. [30, 31, 32, 33, 34, 35]])
  1. c[2, 1, ...] # 相当于c[2, 1, :]

输出:

  1. array([30, 31, 32, 33, 34, 35])
  1. c[2, ..., 3] # 相当于c[2, :, 3]

输出:

  1. array([27, 33])
  1. c[..., 3] # 相当于c[:, :, 3]

输出:

  1. array([[ 3, 9],
  2. [15, 21],
  3. [27, 33],
  4. [39, 45]])

布尔索引

还可以在一个轴上提供一系列布尔值,来指定要访问的索引。

  1. d = np.arange(48).reshape(4, 12)
  2. d

输出:

  1. array([[ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11],
  2. [12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23],
  3. [24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35],
  4. [36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47]])
  1. rows_on = np.array([True, False, True, False])
  2. b[rows_on, :] # 相当于b[(0, 2), :]

输出:

  1. array([[ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11],
  2. [24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35]])
  1. cols_on = np.array([False, True, False] * 4)
  2. b[:, cols_on] # 相当于b[:, (1, 4, 7, 10)]

输出:

  1. array([[ 1, 4, 7, 10],
  2. [13, 16, 19, 22],
  3. [25, 28, 31, 34],
  4. [37, 40, 43, 46]])

np.ix_

不能以上面那种方式在多个轴上使用布尔索引,但是可以使用np.ix_函数来解决。

  1. d[np.ix_(rows_on, cols_on)]

输出:

  1. array([[ 1, 4, 7, 10],
  2. [25, 28, 31, 34]])
  1. np.ix_(rows_on, cols_on)

输出:

  1. (array([[0],
  2. [2]], dtype=int64), array([[ 1, 4, 7, 10]], dtype=int64))

如果使用与ndarray形状相同的布尔数组,会得到一个一维数组,该数组包含所有坐标为True的元素值,通常与条件运算符一起使用。

  1. b[b % 3 == 1]

输出:

  1. array([ 1, 4, 7, 10, 13, 16, 19, 22, 25, 28, 31, 34, 37, 40, 43, 46])

numpy教程04---ndarray的索引的更多相关文章

  1. 转:Numpy教程

    因为用到theano写函数的时候饱受数据结构困扰 于是上网找了一篇numpy教程(theano的数据类型是基于numpy的) 原文排版更好,阅读体验更佳: http://phddreamer.blog ...

  2. Python 机器学习库 NumPy 教程

    0 Numpy简单介绍 Numpy是Python的一个科学计算的库,提供了矩阵运算的功能,其一般与Scipy.matplotlib一起使用.其实,list已经提供了类似于矩阵的表示形式,不过numpy ...

  3. numpy教程

    [转]CS231n课程笔记翻译:Python Numpy教程 原文链接:https://zhuanlan.zhihu.com/p/20878530 译者注:本文智能单元首发,翻译自斯坦福CS231n课 ...

  4. NumPy 教程目录

    NumPy 教程目录 1 Lesson1--NumPy NumPy 安装 2 Lesson2--NumPy Ndarray 对象 3 Lesson3--NumPy 数据类型 4 Lesson4--Nu ...

  5. Mysql实战45讲 04讲深入浅出索引(上)读书笔记 极客时间

    极客时间 Mysql实战45讲 04讲深入浅出索引 极客时间(上)读书笔记  笔记体悟 1.索引的作用:提高数据查询效率2.常见索引模型:哈希表.有序数组.搜索树3.哈希表:键 - 值(key - v ...

  6. [译]Vulkan教程(04)基础代码

    [译]Vulkan教程(04)基础代码 General structure 通用结构 In the previous chapter you've created a Vulkan project w ...

  7. 【GStreamer开发】GStreamer播放教程04——既看式流

    目的 在<GStreamer基础教程--流>里面我们展示了如何在较差的网络条件下使用缓冲这个机制来提升用户体验.本教程在<GStreamer基础教程--流>的基础上在扩展了一下 ...

  8. Elasticsearch入门教程(三):Elasticsearch索引&映射

    原文:Elasticsearch入门教程(三):Elasticsearch索引&映射 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文 ...

  9. 【转】numpy教程

    [转载说明] 本来没有必要转载的,只是网上的版本排版不是太好,看的不舒服.所以转过来,重新排版,便于自己查看. 基础篇 NumPy的主要对象是同种元素的多维数组. 这是一个所有的元素都是一种类型.通过 ...

随机推荐

  1. WPF之VisualTreeHelper

     /// <summary>        /// </summary>        /// <typeparam name="T">< ...

  2. linux内存(三)内核与用户空间交互

    来自网址http://www.kerneltravel.net/jiaoliu/005.htm 用户程序和内核的信息交换是双向的,也就是说既可以主动从用户空间向内核空间发送信息,也可以从内核空间向用户 ...

  3. 使用digispark制作一个BadUSB

    0X00.工具准备 digispark开发板. 淘宝连接:https://m.tb.cn/h.VK7vwjy?sm=d85844 0X01.安装Arduino IDE环境 1.安装 arduino 的 ...

  4. 12.8 typora快捷键

    Markdown学习 标题: n个#号 字体 粗体:要加粗的字两边加两个** 如 ** 粗体** 斜体:两边一个*号 斜体加粗: 两边三个*号 删除线:两边两个波浪号 引用 github 左边一个大于 ...

  5. TTL、RS232、RS485、UART、串口的关系和常见半双工、全双工协议

    串口(UART口).COM口.USB口.DB9.DB25是指的物理接口形式(硬件) TTL.RS-232.RS-485是指的电平标准(电平信号)   我们单片机嵌入式常用的串口有三种(TTL/RS-2 ...

  6. MM32F0140的复位脚nRST复用成普通GPIO PA10功能

    目录: 1.MM32F0020简介 2.MM32F0020的复位脚nRST和PA10的说明 3.MM32F0020的选项字节说明 4.MM32F0020的FLASH_OBR选项字节寄存器说明 5.MM ...

  7. Java常见的垃圾收集器有哪些?

    守拙者_6a98关注 2020.04.11 22:06:31字数 2,135阅读 394 实际上,垃圾收集器( GC , Garbage Collector )是和具体 JVM 实现紧密相关的,不同厂 ...

  8. Java IO流处理

    字节流是由字节组成的;字符流是由字符组成的Java里字符由两个字节组成. 1字符=2字节JAVA中的字节流是采用ASCII编码的,字符流是采用好似UTF编码,支持中文的 Java IO流处理 面试题汇 ...

  9. 什么是 MyBatis 的接口绑定?有哪些实现方式?

    接口绑定,就是在 MyBatis 中任意定义接口,然后把接口里面的方法和 SQL 语句绑 定, 我们直接调用接口方法就可以,这样比起原来了 SqlSession 提供的方法我们可 以有更加灵活的选择和 ...

  10. composer安装报错

    问题报错:Fatal error: Declaration of Fxp\Composer\AssetPlugin\Repository\AbstractAssetsRepository::searc ...