内容简介:以上实例不是使用标准 C 或者 Fortran 顺序,选择的顺序是和数组内存布局一致的,这样做是为了提升访问的效率,默认是行序优先(row-major order,或者说是 C-order)上面的所有都是,显示设置顺序,使用给定顺序,循环数据注意上面的循环都ndarray中的对象都是只读的,不能修改循环内容 eg: 打印迭代对象
import numpy as np dt = np.arange(10).reshape((2,5)) print(dt) for numbers in np.nditer(dt): print(numbers,end=' ') 复制代码
2. 循环转置之后的ndarray对象,记住转置方法transpose或者T
print(dt.T) for numbers in np.nditer(dt.T): print(numbers,end=' ') 复制代码
以上实例不是使用标准 C 或者 Fortran 顺序,选择的顺序是和数组内存布局一致的,这样做是为了提升访问的效率,默认是行序优先(row-major order,或者说是 C-order)
- 下面的按照列方式的访问
dt = np.arange(10).reshape((2,5)) print(dt) # 强制使用C print('显示设置使用C') for members in np.nditer(dt,order='C'): print(members,end=' ') else: print('') # '强制使用F' print('显示设置使用F') for members in np.nditer(dt,order='F'): print(members,end=' ') else: print('') 复制代码
上面的所有都是,显示设置顺序,使用给定顺序,循环数据
dt = np.arange(10).reshape((5,2)) print(dt) print('copy对象使用F') for members in np.nditer(dt.copy(order='F')): print(members,end=' ') else: print('') print('转置之后copy对象使用F') for members in np.nditer(dt.T.copy(order='F')): print(members,end=' ') else: print('') 复制代码
注意上面的循环都ndarray中的对象都是只读的,不能修改循环内容 eg: 打印迭代对象
Traceback (most recent call last): File "numpy.function.py", line 64, in <module> members[...] = members*2 ValueError: assignment destination is read-only 使用参数:op_flags=readwrite或者readonly readwrite: 可修改 readonly: 只读的 复制代码
此外还可以指定nditer类拥有的构造器参数flags,参数:
- c_index 可以跟踪 C 顺序的索引 和order='C'一致
- f_index 可以跟踪 Fortran 顺序的索引 和order='F'一致multi-index每次迭代可以跟踪一种索引类型
- external_loop 给出的值是具有多个值的一维数组,而不是零维数组可以理解为不是ndarray对象中的元素
dt = np.linspace(10,58,24,dtype='int').reshape((4,6)) print(dt) print('打印迭代对象') for members in np.nditer(dt,op_flags=['readwrite']): # print(members[...]) members[...] = members*2 print(members,end=' ') else: print('') print(dt) dt = np.logspace(1,10,20,dtype='int').reshape((5,4)) print(dt) # 遍历所有对象,合并成一个对象 for members in np.nditer(dt,flags=['external_loop'],order='F'): print(members,end=', ') else: print('') 复制代码
如果两个对象是可以广播的,则可以迭代两个对象
dt1 = np.array([[2,3,4],[4,5,6],[6,53,2]]) dt2 = np.arange(3,12).reshape((3,3)) print('两个可迭代对象的元素是:') for x,y in np.nditer([dt1,dt2]): print('{}:{}'.format(x,y),end=' ') print('') 复制代码
下面全是numpy的一些函数,包括以下几大类:
- 修改数组形状 【必须显示的给定形状. eg:(4,5)】
- 翻转数组
- 修改数组维度
- 连接数组
- 分割数组
- 数组元素的添加与删除
np.reshape第三个参数 order='C','F','A' order:'C' -- 按行,'F' -- 按列,'A' -- 原顺序,'k' -- 元素在内存中的出现顺序。
print('函数相关!') # reshape dt = np.asarray([[1,2,3,4],[4,5,6,7],[5,6,7,8]]) print(dt) dt = np.reshape(dt,(2,6)) print(dt) dt = dt.reshape((6,2)) print(dt) 复制代码
flat元素可迭代对象,注意是个对象
print('原始数组') for i in dt: print(i) print('flat元素可迭代后的数组') for members in dt.flat: print(members) 复制代码
flatten,返回一组拷贝,并且对拷贝所做的修改不会影响原始数组,类似于deepcopy,格式如下:ndarray.flatten(order='C') order:'C' -- 按行,'F' -- 按列,'A' -- 原顺序,'K' -- 元素在内存中的出现顺
print('flatten元素可迭代后的数组') for members in dt.flatten(order='C'): print(members) 复制代码
不同风格的展开数组,以 C 风格展开数组和以 F 风格顺序展开的数组
flatten意思是变平,展平
print('使用flatten展平对象') print(dt.flatten()) print(dt.flatten(order='F')) # print(dt.flat()) 复制代码
np.ravel展平对象,这个是数组视图(view,有点类似 C/C++引用reference的意味),修改会影响原始数组。order:'C' -- 按行,'F' -- 按列,'A' -- 原顺序,'K' -- 元素在内存中的出现顺序。该函数接收两个参数:数组和顺序,ravel(dt,order='C')
print('使用ravel展平对象') print(dt.ravel()) print(dt.ravel(order='F')) 复制代码
- 翻转数组
- dt.transpose() 【开始的时候已经使用过】
- dt.T 和上面的函数一致
- rollaxis 向后翻转指定轴
- swapaxes 交换两个轴
print('数组转置') print(dt) print('数组转置T') print(dt.T) print('数组转置transpose') print(dt.transpose()) 复制代码
2019-06-30,太多了,无法一次整理完成 ...待续
数组的rollaxis,交换两个轴
print(np.rollaxis(dt,0,1)) 复制代码
数组函数包括:
- 位运算
- 字符串函数
- 数学函数
- 算数函数
- 统计函数
- 排序,条件刷新函数
- 字节交换
以上所述就是小编给大家介绍的《ndarray可迭代对象,函数,运算》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 迭代器萃取与反向迭代器
- 浅谈python可迭代对象,迭代器
- 可迭代对象,迭代器(对象),生成器(对象)
- 终于把动态规划与策略迭代、值迭代讲清楚了
- 终于把动态规划与策略迭代、值迭代讲清楚了
- 【Java】使用位运算(&)代替取模运算(%)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。