NumPy 学习笔记(二)
数组索引:
1、ndarray对象的内容可以通过索引或切片来访问和修改,与 Python 中 list 的切片操作一样;
由于数组可能是多维的,所以必须为数组的每个维度指定一个切片,使用切片时返回的是一个子数组
2、整数索引:获取相应下标的元素的值
3、布尔数组索引:布尔索引通过布尔运算来获取符合指定条件的元素的数组
4、花式索引:不同的索引之间可以相互搭配,同时也可以和切片一起使用
import numpy as np arr = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9]])
# 切片,返回 arr[:2][1:] 的相应元素
arr_t = arr[:2, 1:] # 输出 arr_t: [[2 3] [5, 6]]
print("arr[:2, 1:]: ", arr_t) # 整数索引允许使用相应下标组成的多维数组
# 这里输出 arr[0][1], arr[1][-1], arr[-1][0]
arr_t = arr[[0, 1, -1], [1, -1, 0]]
print("arr_t: ", arr_t) # 输出 arr_t: [2 6 7] # 布尔索引使用布尔运算选出符合条件的元素
arr_t = arr[arr > 5]
print("arr > 5: ", arr_t)
arr_t = arr[arr % 2 == 1] # [6 7 8 9]
print("arr % 2 == 1: ", arr_t) # [1 3 5 7 9] # 组合索引
# arr[row, col] row指定行,col 指定列,其切片方法与 python 操作一样
arr_t = arr[::2, ::2]
print("arr[::2, ::2]: ", arr_t) # 输出 [[1 3] [7 9]]
# 对元素值大于 5 的元素组成的子数组进行切片
arr_t = arr[arr > 5][::2]
print("arr[arr > 5][::2]: ", arr_t) # 输出 [6 8]
# 对行进行切片,同时获取列为 0 的元素,这里为 arr[1][0], arr[2][0]
arr_t = arr[1:, 0]
print("arr[1:, 0]: ", arr_t) # 输出 [4 7]
arr_t = arr[-1, :]
print("arr[-1, :]: ", arr_t) # 同理,输出 [7 8 9]
NumPy 广播:
1、广播是 numpy 对不同形状(shape)的数组进行数值计算的方式
2、如果两个数组 a 和 b 形状相同,即满足 a.shape == b.shape,那么 a 与 b 的算术运算在对应位进行
3、广播规则:
①让所有输入数组都向其中形状最长的数组看齐,形状中不足的部分都通过在前面加 1 补齐
②输出数组的形状是输入数组形状的各个维度上的最大值
③如果输入数组的某个维度和输出数组的对应维度的长度相同或者其长度为 1 时,这个数组能够用来计算,否则出错
④当输入数组的某个维度的长度为 1 时,沿着此维度运算时都用此维度上的第一组值
import numpy as np one = np.arange(1, 26)
# 修改数组形状为 5*5
one.shape = (5, 5)
print("one: ", one)
# 生成 [50...25) 的数组
two = np.arange(50, 25, -1)
two.shape = (5, 5)
print("two: ", two)
print("one + two: ", one + two) arr_one = np.array([[1, 2, 3, 4], [5, 6, 7, 8]])
arr_two = np.array([1, 2, 3, 4])
# 输出 [[2 3 6 8] [6 8 10 12]]
print("arr_one + arr_two: ", arr_one + arr_two)
arr_two = np.array([[1], [2]])
# 输出 [[2 3 4 5] [7 8 9 10]]
print("arr_one + arr_two: ", arr_one + arr_two) arr_two = np.array([2])
# 输出 [[2 4 6 8] [10 12 14 16]]
print("arr_one * arr_two: ", arr_one * arr_two)
迭代数组:
1、NumPy 1.6 中引入的迭代器对象 nditer
提供了许多灵活的方式来以系统的方式访问一个或多个数组的所有元素
2、nditer 使用标准 Python 迭代器接口逐个提供每个元素
3、nditer
对象提供了一个 order 参数来控制迭代的顺序,默认 order="K",即保持原有顺序
4、默认情况下,nditer 将输入数组视为只读对象。 要修改数组元素,必须指定读写或只写模式
5、外部循环:若不使用外部循环,则数组的每个元素由迭代器一次提供一个;我们可以将一维最内层循环移动到迭代器外部的代码中,
通过强制'C'和'F'顺序,而得到不同的外部循环大小。 需要我们通过指定迭代器标志来启用此模式
import numpy as np # 产生 [0, 2pi] 的等差数组,其元素个数为 9
arr = np.linspace(0, 2 * np.pi, 9)
arr.shape = (3, 3)
print("Order is C") # 按行
for o in np.nditer(arr):
print(o) print("Order is F") # 按列
for o in np.nditer(arr.copy(order="F")):
print(o) # 默认情况下,nditer将输入数组视为只读对象。 要修改数组元素,必须指定读写或只写模式
arr = np.arange(6).reshape(2, 3)
for o in np.nditer(arr):
o = o*2
print("arr: ", arr) # 没有改变
for o in np.nditer(arr, op_flags=["readwrite"]):
# 注意需要使用省略号索引
o[...] = o*2
print("arr: ", arr) # 外部循环
arr = np.linspace(1, 6, 6).reshape(2, 3)
# 输出 [1. 2. 3. 4. 5. 6.] 注意和之前的区别
for o in np.nditer(arr, flags=["external_loop"]):
print("arr: ", o)
time = 0
# 通过强制'C'和'F'顺序,我们得到不同的外部循环大小
for o in np.nditer(arr, flags=["external_loop"], order="F"):
print("arr", time, ": ", o)
time += 1 # 跟踪索引
# 跟踪索引或多索引与使用外部循环不兼容,因为它需要每个元素具有不同的索引值
it = np.nditer(arr, flags=["multi_index"])
lst = []
while not it.finished:
print("value: {}\nmulti_index: <{}>".format(it[0], it.multi_index))
lst.append(it.multi_index[1] - it.multi_index[0])
it.iternext()
print("All it.multi_index[1] - it.multi_index[0]: ", lst)
注:Python中的常规赋值只是更改本地或全局变量字典中的引用,而不是修改现有变量。 这意味着简单地分配给 x 不会将值放入数组的元素中,
而是将 x 作为数组元素引用切换为对指定值的引用。 要实际修改数组的元素,x应该用省略号索引
NumPy 学习笔记(二)的更多相关文章
- NumPy学习笔记 二
NumPy学习笔记 二 <NumPy学习笔记>系列将记录学习NumPy过程中的动手笔记,前期的参考书是<Python数据分析基础教程 NumPy学习指南>第二版.<数学分 ...
- NumPy学习笔记 一
NumPy学习笔记 一 <NumPy学习笔记>系列将记录学习NumPy过程中的动手笔记,前期的参考书是<Python数据分析基础教程 NumPy学习指南>第二版.<数学分 ...
- numpy 学习笔记
numpy 学习笔记 导入 numpy 包 import numpy as np 声明 ndarray 的几种方法 方法一,从list中创建 l = [[1,2,3], [4,5,6], [7,8,9 ...
- Numpy学习笔记(下篇)
目录 Numpy学习笔记(下篇) 一.Numpy数组的合并与分割操作 1.合并操作 2.分割操作 二.Numpy中的矩阵运算 1.Universal Function 2.矩阵运算 3.向量和矩阵运算 ...
- Numpy学习笔记(上篇)
目录 Numpy学习笔记(上篇) 一.Jupyter Notebook的基本使用 二.Jpuyter Notebook的魔法命令 1.%run 2.%timeit & %%timeit 3.% ...
- tensorflow学习笔记二:入门基础 好教程 可用
http://www.cnblogs.com/denny402/p/5852083.html tensorflow学习笔记二:入门基础 TensorFlow用张量这种数据结构来表示所有的数据.用一 ...
- WPF的Binding学习笔记(二)
原文: http://www.cnblogs.com/pasoraku/archive/2012/10/25/2738428.htmlWPF的Binding学习笔记(二) 上次学了点点Binding的 ...
- AJax 学习笔记二(onreadystatechange的作用)
AJax 学习笔记二(onreadystatechange的作用) 当发送一个请求后,客户端无法确定什么时候会完成这个请求,所以需要用事件机制来捕获请求的状态XMLHttpRequest对象提供了on ...
- [Firefly引擎][学习笔记二][已完结]卡牌游戏开发模型的设计
源地址:http://bbs.9miao.com/thread-44603-1-1.html 在此补充一下Socket的验证机制:socket登陆验证.会采用session会话超时的机制做心跳接口验证 ...
- JMX学习笔记(二)-Notification
Notification通知,也可理解为消息,有通知,必然有发送通知的广播,JMX这里采用了一种订阅的方式,类似于观察者模式,注册一个观察者到广播里,当有通知时,广播通过调用观察者,逐一通知. 这里写 ...
随机推荐
- CNA, FCoE, TOE, RDMA, iWARP, iSCSI等概念及 Chelsio T5 产品介绍 转载
CNA, FCoE, TOE, RDMA, iWARP, iSCSI等概念及 Chelsio T5 产品介绍 2016年09月01日 13:56:30 疯子19911109 阅读数:4823 标签: ...
- linux 网络虚拟化: network namespace 简介
linux 网络虚拟化: network namespace 简介 network namespace 是实现网络虚拟化的重要功能,它能创建多个隔离的网络空间,它们有独自的网络栈信息.不管是虚拟机还是 ...
- LCA的两种写法
第一种是离线的Tarjan算法 #include<cstdio> using namespace std; int rd(){ ,fl=;char ch=getchar(); ;}ch=g ...
- EasyPR源码剖析(5):车牌定位之偏斜扭转
一.简介 通过颜色定位和Sobel算子定位可以计算出一个个的矩形区域,这些区域都是潜在车牌区域,但是在进行SVM判别是否是车牌之前,还需要进行一定的处理.主要是考虑到以下几个问题: 1.定位区域存在一 ...
- mysql导出导入数据
使用sql语句导出数据: 导出时如果不写绝对路径,会提示The MySQL server is running with the --secure-file-priv option so it can ...
- Java第4次实训作业
编写"电费管理类"及其测试类. 第一步 编写"电费管理"类 私有属性:上月电表读数.本月电表读数 构造方法:无参.2个参数 成员方法:getXXX()方法.se ...
- python3 第二十七章 - 内置函数之str相关
Python 的字符串常用内建函数如下: 序号 方法及描述 实例 1 capitalize()将字符串的第一个字符转换为大写 2 center(width, fillchar) 返回一个指定的宽度 ...
- LNMP支持 多版本PHP
1.到 http://www.php.net/downloads.php(http://www.php.net/downloads.php) 选择合适的版本号,如 5.6.34 2.到 LNMP 1. ...
- windows 2008解决120天授权过期问题(亲测可用)
https://blog.csdn.net/tladagio/article/details/80503198 最后的注册号码可以是:就是那个注册号码:5296992 4954438 6565792. ...
- mysql利用LAST_INSERT_ID实现id生成器
首先了解 LAST_INSERT_ID LAST_INSERT_ID 有自己的存储空间,能存一个数字 不带参数时返回最近insert的那行记录的自增字段值.带参数时会将自己存储的数字刷成参数给定的值 ...