numpy.divmod

numpy.divmod(x1, x2, [out1, out2, ]/, [out=(None, None), ]*, where=True, casting='same_kind', order='K', dtype=None, subok=True[, signature, extobj]) = <ufunc 'divmod'>

同时返回元素商和余数。

1.13.0 新版功能.

np.divmod(x, y) 等于 (x // y, x % y) 但速度更快,因为它避免了冗余工作。用于实现python内置函数 divmod 在numpy数组上。

参数
x1array_like

红利数组。

x2array_like

除数数组。如果 x1.shape != x2.shape ,它们必须可以广播到公共形状(成为输出的形状)。

outndarray、none或ndarray和none的元组,可选

存储结果的位置。如果提供,它必须具有输入广播到的形状。如果未提供或没有,则返回新分配的数组。元组(只能作为关键字参数)的长度必须等于输出数。

where阵列式,可选

这种情况通过输入广播。在条件为真的位置 out 数组将被设置为ufunc结果。在其他地方 out 数组将保留其原始值。请注意,如果未初始化 out 数组是通过默认值创建的 out=None ,其中条件为False的位置将保持未初始化状态。

**kwargs

有关其他仅限关键字的参数,请参见 ufunc docs .

返回
out1恩达雷

楼层划分产生的元素商。这是一个标量,如果两者都是 x1x2 是标量。

out2恩达雷

按元素排序的楼层划分余数。这是一个标量,如果两者都是 x1x2 是标量。

参见

floor_divide

相当于python的 // 操作员。

remainder

相当于python的 % 操作员。

modf

相当于 divmod(x, 1) 为正 x 返回值切换。

实例

>>> np.divmod(np.arange(5), 3)
(array([0, 0, 0, 1, 1]), array([0, 1, 2, 0, 1]))

这个 divmod 函数可以用作 np.divmod 在星期天。

>>> x = np.arange(5)
>>> divmod(x, 3)
(array([0, 0, 0, 1, 1]), array([0, 1, 2, 0, 1]))