NumPy是Python数值计算最重要的基础包,提供了以下功能(不限于此)
快速高效的多(duo)维数组对象ndarray。
用于对数组执行元素级计算以及直接对数组执行数学(xue)运算的函数。
用于读写硬盘上基于数组的数据集的工具。
线性代数运算、傅里叶变换,以及随机数生成。
成熟的C API, 用于Python插件和原生C、C++、Fortran代码访问 NumPy的数据结构和计算工具。
NumPy之于数值计算特别重要的原因之一,是因为它可以高效处理大数组的数据。这是因为:
NumPy是在一个连续的内存块中存储数据,独立于其他Python内置对象。NumPy的C语言编写的算法库可以操作内存,而不必进行类型检查或其它前期工作。比起Python的内置序列,NumPy数组使用的内存更少。
NumPy可以在整个数组上执行复杂的计算,而不需要Python的for循环。
1.1 NumPy引入方式
NumPy使用的内存更小,运算效率也更高,我们来比较一下NumPy和Python自带的列表的性能:
NumPy比Python自带的列表快了一个数量级。
1.2ndarrary:多(duo)维数组对象
多(duo)维数组对象ndarray是一个快速而灵活的数据集容器。我们可以利用这种数组对整块数据执行一些数学(xue)运