numpy.copy#
- numpy.copy(a, order='K', subok=False)[来源]#
返回给定对象的数组副本。
- 参数:
- a类数组
输入数据。
- order{‘C’, ‘F’, ‘A’, ‘K’}, 可选
控制副本的内存布局。‘C’ 表示 C 顺序,‘F’ 表示 F 顺序,如果 a 是 Fortran 连续的,‘A’ 表示 ‘F’,否则表示 ‘C’。‘K’ 表示尽可能匹配 a 的布局。(请注意,此函数与
ndarray.copy
非常相似,但其 order= 参数的默认值不同。)- subok布尔, 可选
如果为 True,则子类将直接通过,否则返回的数组将被强制为基类数组(默认为 False)。
- 返回:
- arrndarray
a 的数组解释。
另请参阅
ndarray.copy
创建数组副本的首选方法
注意
这等同于
>>> np.array(a, copy=True)
数据副本是浅拷贝,即对于具有 object dtype 的数组,新数组将指向相同的对象。请参阅
ndarray.copy
中的示例。示例
>>> import numpy as np
创建一个数组 x,其中 y 是一个引用,z 是一个副本
>>> x = np.array([1, 2, 3]) >>> y = x >>> z = np.copy(x)
请注意,当我们修改 x 时,y 会随之改变,但 z 不会
>>> x[0] = 10 >>> x[0] == y[0] True >>> x[0] == z[0] False
请注意,np.copy 会清除之前设置的 WRITEABLE=False 标志。
>>> a = np.array([1, 2, 3]) >>> a.flags["WRITEABLE"] = False >>> b = np.copy(a) >>> b.flags["WRITEABLE"] True >>> b[0] = 3 >>> b array([3, 2, 3])