sql >> Base de Datos >  >> RDS >> Oracle

Cómo instalar cx_Oracle en El Capitán

Intenté lo anterior y obtuve el siguiente error al intentar instalar cx_Oracle usando Oracle instantclient 12.1 :

[535]: /opt/instantclient_12_1 $ python -c "import cx_Oracle"
Traceback (most recent call last):
  File "<string>", line 1, in <module>
ImportError: dlopen(/Library/Python/2.7/site-packages/cx_Oracle.so, 2): 
        Library not loaded: @rpath/libclntsh.dylib.12.1
  Referenced from: /Library/Python/2.7/site-packages/cx_Oracle.so
  Reason: image not found

Observe el @rpath en el error:resulta que al compilar la biblioteca cx_Oracle (para instantclient 12.1) en El Capitan, el compilador gcc espera que se establezca el indicador -rpath para saber dónde encontrar las bibliotecas vinculadas dinámicamente antes mencionadas (*.dylib). De forma predeterminada, en instantclient 12.1, pip no hace esto por ti.

# Set -rpath option before installing...this will use $ORACLE_HOME during compilation
export FORCE_RPATH=TRUE
pip install cx_Oracle
# And verify cx_Oracle was correctly installed
python -c "import cx_Oracle"
# If this line fails install cx_Oracle with:
#   pip install --no-cache-dir --allow-external --allow-unverified cx_oracle

El python -c "import cx_Oracle" no debe informar ningún error.

Para obtener una guía de instalación completa (que incluye la descarga y configuración del cliente instantáneo), consulte mi publicación en http://thelaziestprogrammer.com/sharrington/databases/oracle/install-cx_oracle-mac para más detalles.