直接对非零元素运算可避免显式布尔掩码变量:用a[a!=0] = 2原地修改;np.where(a!=0, a3, a)生成新数组;np.copyto(a[np.nonzero(a)], a[np.nonzero(a)]**2)省内存;一维用np.flatnonzero更高效。
直接对非零元素执行运算而不显式创建布尔掩码数组,关键在于利用 numpy 的高级索引和原地操作能力。虽然“不创建掩码数组”在底层往往难以完全避免(例如 a != 0 仍会临时生成布尔数组),但可以做到**不保留掩码变量、不额外分配掩码内存、不显式赋值给中间变量**,从而实现简洁高效的操作。
np.where 配合原地赋值适用于“对非零元素除以某数”“加某偏移”等简单逐元素运算,且希望结果写回原数组或新数组:
np.where 实现条件表达式,逻辑清晰,不显式存储掩码np.copyto + 条件索引(更省内存)当目标是把运算结果写入已有数组(尤其是大数组),且想避免 np.where 的全量输出开销时:
np.nonzero 获取非零位置的索引元组,再用于高级索引np.copyto 支持原地写入,且不产生中间布尔数组变量np.flatnonzero 更轻量比 np.nonzero 更快、更省内存(只返回一维索引),适合扁平化场景:
np.log, np.sqrt)只作用于非零值这些方法都依赖 a != 0 或 np.nonzero 的内部判断,需注意:
== 0,建议用 np.isclose(a, 0) 替代,但会多一次计算a[a != 0] = ... 在视图/副本行为上需确保 a 是可写的(a.flags.writeable 为 True)a[a!=0] = np.exp(a[a!=0])),会触发两次索引——此时 np.where 或 np.copyto 更可控