use*_*245 5 python cx-oracle environment-variables python-3.x
cx_Oracle for Python需要设置某些环境变量才能正确导入和工作。我没有尝试将我的应用程序包装在过去的bash脚本中,而是尝试仅使用Python设置变量。
以下是到目前为止我所拥有的。
# Check if OS environment variables are setup.
if 'ORACLE_HOME' not in os.environ.keys():
os.environ['ORACLE_HOME'] = '/usr/lib/oracle/12.1/client64'
if 'LD_LIBRARY_PATH' not in os.environ.keys():
os.environ['LD_LIBRARY_PATH'] = os.environ['ORACLE_HOME'] + '/lib'
if '/usr/lib/oracle' not in os.environ['PATH']:
os.environ['PATH'] = os.environ['ORACLE_HOME'] + '/bin:' + os.environ['PATH']
import cx_Oracle
Run Code Online (Sandbox Code Playgroud)
不幸的是,我仍然收到来自cx_Oracle的异常,这基本上意味着变量未正确设置。
我也尝试使用subprocess.Popen()和subprocess.call()直接调用导出,但是我不确定它们是否不能正常工作,或者我不能正确理解这些功能。
设置这些变量的最佳方法是什么,这样我就可以仅使用Python 3导入cx_Oracle。
编辑,下面是我通常添加到bash包装器中的内容:
#!/bin/sh
# Initialize Environmental Variables for cx_Oracle
export ORACLE_HOME=/usr/lib/oracle/12.1/client64
export LD_LIBRARY_PATH=$ORACLE_HOME/lib
export PATH=$ORACLE_HOME/bin:$PATH
(Python Script)
Run Code Online (Sandbox Code Playgroud)
这个问题很可能已经在这个网站上得到了回答: How to Changeenvironment Variables in python? 我引用已接受的答案:
您可以这样设置它们,但是 $LD_LIBRARY_PATH 是由之前已经运行过的加载程序读取的,因此您必须事先在外部设置该路径。