Ich versuche ein Python-Skript zu packen, das GDAL für PyPI verwendet. Ich begann damit, eine direkte Referenz in meine setup.py
:
install_requires=['GDAL==1.11.2'],
Auf diese Weise konnte das Paket in meiner virtuellen Testumgebung nicht installiert werden:
extensions/gdal_wrap.cpp:2855:22: fatal error: cpl_port.h: No such file or directory
#include "cpl_port.h"
^
compilation terminated.
error: Setup script exited with error: command 'x86_64-linux-gnu-gcc' failed with exit status 1
Ich habe es dann mit einem Verweis auf versucht pygdal
, da es als virtualenv-freundliche Version markiert ist:
install_requires=['pygdal'],
Auf diese Weise wird die Installation fehlerfrei abgeschlossen (jedoch mit den üblichen Kompilierungswarnungen). Wenn ich dann das Skript aufrufe, erhalte ich diesen Fehler zurück:
Traceback (most recent call last):
File "/home/desouslu/.virtualenvs/test_p3/bin/hasc2gml", line 5, in <module>
from pkg_resources import load_entry_point
File "/home/desouslu/.virtualenvs/test_p3/lib/python3.4/site-packages/pkg_resources.py", line 2716, in <module>
working_set.require(__requires__)
File "/home/desouslu/.virtualenvs/test_p3/lib/python3.4/site-packages/pkg_resources.py", line 685, in require
needed = self.resolve(parse_requirements(requirements))
File "/home/desouslu/.virtualenvs/test_p3/lib/python3.4/site-packages/pkg_resources.py", line 588, in resolve
raise DistributionNotFound(req)
pkg_resources.DistributionNotFound: pygdal
Was ist der richtige Weg, um GDAL als Abhängigkeit festzulegen?
Update : Die Abhängigkeit scheint korrekt deklariert zu sein, das Problem ist wahrscheinlich vorgelagert, mit dem GDAL-Paket selbst. Weitere Details bei StackOverflow .
Antworten:
Vor der Installation der GDAL-Python-Bindung müssen Sie GDAL auf Ihrem System installieren.
Danach setzen Sie Variablen und installieren die Bindung
Die Version des System-GDAL sollte höher sein als die Versionsbindungen.
quelle