我想知道为什么 python pandas 不为 Linux 上的 pip 安装提供 .whl 文件。不过,Whl 文件可用于 Mac 和 Windows。参见:https://pypi.python.org/pypi/pandas/0.18.1

我可以

pip install pandas

但这涉及从源头构建的耗时过程。我有一个包含 Pandas 作为构建依赖项的持续集成系统,因此我希望能够从二进制 .whl 文件快速安装,而无需从源代码构建。

最佳答案

Armin Ronacher 对此进行了详细讨论。从根本上说,Linux 发行版不够统一,您不能依赖特定库的存在来链接;甚至python库也可能不一致。

您可以为正在使用的环境构建自己的轮子,并根据需要安装它们,这对于持续集成系统应该可以正常工作:

$ pip wheel pandas
Collecting pandas
  Downloading pandas-0.18.1.tar.gz (7.3MB)
    100% |████████████████████████████████| 7.3MB 131kB/s
...
Successfully built pandas

$ ls pandas*
pandas-0.18.1-cp35-cp35m-linux_x86_64.whl

$ pip install pandas-0.18.1-cp35-cp35m-linux_x86_64.whl
Processing ./pandas-0.18.1-cp35-cp35m-linux_x86_64.whl
...
Successfully installed pandas-0.18.1 python-dateutil-2.5.3 pytz-2016.4 six-1.10.0

请注意,numpy 确实在 pypi 上提供了 linux 轮文件。查看内部(它们是简单的 zip 文件),我们可以看到它们捆绑了常用的 numpy 库,例如 lapack_lite 以及它们的依赖项(在这种情况下为 gfortran 和 openblas):
$ unzip -l numpy-1.11.0-cp35-cp35m-manylinux1_x86_64.whl  | grep [.]so

...
 38407360  2016-04-12 21:01   numpy/.libs/libopenblasp-r0-39a31c03.2.18.so
  1017104  2016-04-12 21:01   numpy/.libs/libgfortran-ed201abd.so.3.0.0
   108200  2016-04-12 21:01   numpy/linalg/lapack_lite.cpython-35m-x86_64-linux-gnu.so
...

相比之下,由 O/S 安装的 numpy 将 lapack_lite 链接到/usr/lib/libblas,它通过 debian 替代系统链接到优化的 libatlas,因此它应该具有更好的性能(未经测试)。

查看 lapack 链接,它们使用的是非常标准的库,因此它应该适用于许多 64 位 linux 系统:
$ ldd lapack_lite.cpython-35m-x86_64-linux-gnu.so
    linux-vdso.so.1 =>  (0x00007fffadf7a000)
    libopenblasp-r0-39a31c03.2.18.so => /tmp/numpy/linalg/./../.libs/libopenblasp-r0-39a31c03.2.18.so (0x00007f5efb8bc000)
    libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f5efb69e000)
    libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f5efb2d9000)
    libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f5efafd3000)
    libgfortran-ed201abd.so.3.0.0 => /tmp/numpy/linalg/./../.libs/libgfortran-ed201abd.so.3.0.0 (0x00007f5efacda000)
    /lib64/ld-linux-x86-64.so.2 (0x00007f5efe0d4000)

据推测,有人也可以自愿为 Pandas 创建轮子,并在不同版本的 python 中保持它们的最新状态。请注意,pandas .so 文件链接到 libpython,但尽管进行了 python 调用,但 numpy 以某种方式避免这样做。

编辑 2016-05-25:添加了构建和安装轮子的说明。

关于python - 为什么python pandas不提供Linux whl文件,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/37427294/

10-12 16:45
查看更多