.npy 文件是 NumPy 库用于存储数组数据的二进制格式,它包含一个描述数组结构的头部信息和实际的数据部分。直接追加数据到现有的 .npy 文件并不像文本文件那样直接,因为需要手动修改文件头部以反映新增数据后的数组尺寸,并且要确保数据正确地附加到现有数据之后。
 
 不过,通常推荐的做法不是直接追加到现有 .npy 文件,而是采取以下步骤:
- 加载现有数据:首先使用 numpy.load()函数加载现有的.npy文件中的数组数据。
- 合并数据:将新数据(同样需要是 NumPy 数组)与加载的数组进行合并。如果你希望按行追加(例如,两个一维数组),可以使用 numpy.concatenate()或numpy.vstack()函数;如果是按列追加(对于二维数组),可以使用numpy.hstack()或调整后使用numpy.concatenate()。
- 保存新数据:将合并后的新数组保存到一个新的 .npy文件中,使用numpy.save()或numpy.savez()函数。
 
 这样做的原因是,.npy 文件格式设计时并未考虑简单的追加操作,直接修改文件可能破坏其内部结构。下面是示例代码:
#pythonimport numpy as np# 加载现有数据
existing_data = np.load('existing_data.npy')# 新数据,确保维度与现有数据兼容
new_data = np.array([...])  # 这里是你的新数据# 按行追加(假设都是二维数组,且列数相同)
combined_data = np.vstack((existing_data, new_data))# 保存到新文件
np.save('new_combined_data.npy', combined_data)如果你确实需要保留原始文件名,并且不想每次追加都创建新文件,理论上可以通过读取并解析 .npy 文件头,手动修改形状信息,然后重新写入数据和更新的头部信息来实现追加,但这涉及到复杂的文件操作和对 .npy 格式的深入了解,通常不建议这样做,除非有特别的需求。