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这里采用了一种订阅的方式,类似于观察者模式,注册一个观察者到广播里,当有通知时,广播通过调用观察者,逐一通知. 这里写 ...
随机推荐
- Python处理word文件
python对word文件进行读写和复制 import win32conimport win32com.clientimport os #读取word文件def readWoldFile(path): ...
- 2-1 如何抓不同的接口(手机抓包,web网页抓包)
举个例子,一个测试和安卓的对话. 测试:Android你这里有个bug Android:这是服务端的bug 测试:是你这里显示的不对 Android:你去看服务端返回数据,他不对,你会不会测试. 从这 ...
- POJ 2368 Buttons
题目链接:http://poj.org/problem?id=2368 Bash game (巴什博弈):当K是(L+1)的倍数时可以确保second player赢.所以这道题要找的就是在K的因子中 ...
- Python中的迭代器、生成器
from collections import Iterable, Iterator 1. 可迭代(iterable)对象 参考官网链接 class I: def __init__(self, v): ...
- bower简明入门教程
什么是bower: Bower是一个客户端技术的软件包管理器,它可用于搜索.安装和卸载如JavaScript.HTML.CSS之类的网络资源.其他一些建立在Bower基础之上的开发工具,如YeoMan ...
- IMPLEMENTATION - Entity Framework Anti Pattern - High Performance EF
Good about ORM Developer is free from building T-Sql on the database tier which is not their major a ...
- easyui combobox 不能选中值的问题
easyui comboxbox 下拉框加载到数据,但是不能选中.一般情况是重复渲染,页面有同名元素,valueField重复. 这次遇到的具体问题是,第一次刷新页面,可以选中,第二次不能选中.考虑到 ...
- 关于python-flask中规范创建项目的几个关键py项目文件
1.config.py——配置文件 DEBUG = True DIALECT = 'mysql' DRIVER = 'mysqldb' USERNAME = 'root' PASSWORD = '' ...
- Django的MVT模式与MVC模式
Django的MVT模式与MVC模式 在正式开始coding之前,我觉得有必要探讨下Django的MVT模式,理论和实践相结合,才能更好的掌握一门技术.Django中的MVT模式,Django就是属于 ...
- Codeforces 873 简要题解
文章目录 A题 B题 C题 D题 E题 F题 传送门 A题 传送门 题意: 一个人要做nnn件事,时间花费分别为a1,a2,...,an,a1≤a2≤a3≤...≤ana_1,a_2,...,a_n, ...