使用Python设置cx_Oracle环境变量

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)

bal*_*ldr 4

这个问题很可能已经在这个网站上得到了回答: How to Changeenvironment Variables in python? 我引用已接受的答案:

您可以这样设置它们,但是 $LD_LIBRARY_PATH 是由之前已经运行过的加载程序读取的,因此您必须事先在外部设置该路径。