zoukankan      html  css  js  c++  java
  • cx_Oracle在sublime text里运行遇到 ImportError错误解决办法

    如果你装完cx_Oracle之后,命令行运行没错,但是在sublime text里运行, 就遇到这个错误:

    ImportError: dlopen(/Library/Python/2.7/site-packages/cx_Oracle.so, 2): Library not loaded: /ade/b/3071542110/oracle/rdbms/lib/libclntsh.dylib.11.1
      Referenced from: /Library/Python/2.7/site-packages/cx_Oracle.so
      Reason: image not found

    那么恭喜你这是可以解决的,原因是由于某些诡异的安全性考虑,环境变量DYLD_LIBRARY_PATH在mac系统中被不正确的继承,导致cx_Oracle.so找不到libclntsh.dylib.11.1。

    那么让我们来人肉告诉cx_Oracle.so它想要的文件在哪

    install_name_tool -change 
      /ade/b/3071542110/oracle/rdbms/lib/libclntsh.dylib.11.1 
      $ORACLE_HOME/libclntsh.dylib.11.1 
      /Library/Python/2.7/site-packages/cx_Oracle.so

    这个命令的作用是:告诉第四行这个文件,它原以为在第二行的东西,其实在第三行。所以你需要根据上面的错误提示写第二行,再根据你自己libclntsg.dylib.11.1存放的位置写第三行,最后根据你想用的python位置写第四行。比如我用得是anaconda python,我第四行就是 /Users/qixiang/anaconda/lib/python2.7/site-packages/cx_Oracle.so 

    然后你会遇到另一个错误,类似于

    ImportError: dlopen(/Library/Python/2.7/site-packages/cx_Oracle.so, 2): Library not loaded: /ade/dosulliv_ldapmac/oracle/ldap/lib/libnnz11.dylib
      Referenced from: /usr/local/lib/share/oracle/installclient_11_2/libclntsh.dylib.11.1
      Reason: image not found

    问题如出一辙:libclntsh.dylib.11.1找不到libnnz11.dylib,解决办法一样

      install_name_tool -change 
      /ade/dosulliv_ldapmac/oracle/ldap/lib/libnnz11.dylib 
      $ORACLE_HOME/libnnz11.dylib 
      $ORACLE_HOME/libclntsh.dylib.11.1

    区别在于在此之前需要赋予修改libclntsh.dylib.11.1的权限:

    chmod 777 $ORACLE_HOME/libclntsh.dylib.11.1

    现在你已经解决了这个问题。

  • 相关阅读:
    MySQL中的char与varchar详解
    有关PHPstorm的git环境的配置和git密钥的生成总结
    PHP开发中常用的字符串操作函数
    PHP 二维数组排序函数的应用 array_multisort()
    大龄程序员的出路在哪里
    近期面试总结(PHP后端开发工程师)(部分笔试题)
    B-Tree目录和Hash索引的区别
    curl、fopen和file_get_contents区别
    什么是OAuth授权
    SEO 统计算法
  • 原文地址:https://www.cnblogs.com/washa/p/5616127.html
Copyright © 2011-2022 走看看