最近,由于项目的短信平台对其它浏览器兼容,只支持IE,但是我们移动端自动化需要测试iphone手机,必须要连接MAC系统下,众所周知,MAC对IE的不友好性,故没办法通过短信平台在UI层自动化获取短信验证码,所以,我们决定直接通过访问短信平台的数据库,从而满足短信验证码的自动化获取功能。
        所用的mac系统是MacOS10.12,Python3.4,cx_oracle(6.0rc2)
一 下载安装python3.4
   macOS10.12其实有自带的python2.7,但是由于项目需要所以需要下载升级,所以我选择了python3.4作为工具
   python3.4下载地址:https://www.python.org/downloads/release/python-344/
     
    下载后直接安装即可。
    注意 :有人说,要使用新的python必须要重新连接而且删除自带的python,其实没有必要,只需要在系统环境变量中加入新下载安装的地址就可以,如需要使用python3.4,只需要在终端输入python3即可,千万不要删除,因为删除了会导致系统用到python的东西会有问题,例如xcode会无法使用。
二 下载oracle instant client
其实若需要访问远程的oracle,不需要下载安装客户端,只需要下载instantclient-basic和instantclient-sdk即可,因为我们不需要建立数据库,只是一个访问,千万不要走了冤枉路,具体下载和安装如下:
1⃣️地址:http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html
 
这个要根据自己的mac选择,一般mac机选择如上图的连接,进去之后根据要连接的oracle版本选择,现在主流的有10g和11g,我要连接的是11g,所以选择如下:
 
下载完之后,两个文件应该是两个文件夹,第一个instantclient-basic-macos.x64-11.2.0.4.0.zip解压(我的事自动解压)为文件夹-instantclient_11_2,第二个也是一个文件夹instantclient_11_2-2,里面有一个sdk的文件夹。你需要做的就是把sdk的整个文件夹复制粘贴到第一个文件夹也就是 instantclient_11_2里面。
2⃣️ 解压ottclasses.zip(这个压缩包在刚才的sdk文件夹中)经过测试,这一步可以省略,具体也不清楚是干嘛的,有大神清楚请赐教
3⃣️ 修改 /etc/profile,增加系统的环境变量,(在这里,有一个坑,就是mac10.12第三方程序禁止访问系统变量,导致最终在python的idle上运行cx_oracle失败,解决办法见下文)
在终端进入etc,并修改环境变量,具体代码如下,我刚才下载的instantclient_11_2文件夹放到了桌面,所以设置的时候地址为我自己的安放目录,这里要根据自己的安放目录设置,我的文件地址:/Users/zdh/Desktop/instantclient_11_2
cd /etc/
sudo chmod 777 profile
vi profile 
export ORACLE_HOME=/Users/zdh/Desktop/instantclient_11_2
export DYLD_LIBRARY_PATH=$ORACLE_HOME
export LD_LIBRARY_PATH=$ORACLE_HOME
保存并返回后,要执行系统变量使其生效,命令如下
source profile
这里系统变量就生效了,可以用在终端输入命令$ORACLE_HOME,出现自己设置的路径就成功了
(其实mac的环境变量又多种设置方法,这是其中之一,大家可以自行去网上查询,这里不做过多阐述)
4⃣️链接库文件
 进到/Users/zdh/Desktop/instantclient_11_2,也就是你刚才放置的地方,执行如下命令
ln -s libclntsh.dylib.11.1 libclntsh.dylib
ln -s libocci.dylib.11.1 libocci.dylib
文件夹中出现这两个就算成功了,如果误操作,生成错了,要先删除了这两个文件,才能再次链接
 

5⃣️安装cx_oracle,如果有网络并且有pip,那就会容易些,需要执行如下命令
python -m pip install cx_Oracle(这个是安装cx_oracle5.3)
python -m pip install cx_Oracle --pre(这个事安装最新的6.0rc2
以上哪个都可以,若没有网络需要现在线下包安装,地址https://oracle.github.io/python-cx_Oracle/
6⃣️  在终端测试一下,运行下图语句若没有报错证明没有问题
 
 -----------上面的内容全部完成后,在终端运行程序并链接oracle已经没有问题,但是在实际项目中不能只在终端运行,我们的项目需要用python的IDLE来执行,由于macOS 的安全机制,用IDLE执行会出现一些问题,具体问题以及解决方法如下
问题1: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系统的环境变量没有正确的继承导致,cx_Oracle.so找不到libclntsh.dylib.11.1,我们需要来人肉告诉cx_Oracle.so它想要的文件在哪,命令如下(注意这是一行代码,最后面的是你自己的python安装目录):
install_name_tool -change /ade/b/3071542110/oracle/rdbms/lib/libclntsh.dylib.11.1 $ORACLE_HOME/libclntsh.dylib.11.1 /Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/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的权限
chmod 777 $ORACLE_HOME/libclntsh.dylib.11.1
install_name_tool -change /ade/dosulliv_ldapmac/oracle/ldap/lib/libnnz11.dylib $ORACLE_HOME/libnnz11.dylib $ORACLE_HOME/libclntsh.dylib.11.1
问题2:cx_Oracle.InterfaceError: Unable to acquire Oracle environment handle
这个问题是有macos系统的sip安全机制导致 ,需要关闭sip,方法是:

  • 关机-开机-按住CMD+R-等待进入恢复模式
  • 工具-终端-执行如下命令
  • csrutil disable

然后重新启动系统,则设置成功,当然开启sip,方法一样,命令为csrutil enable 
问题3:上面的东西都设置完成之后,依然会报错的那就是极品问题了,不幸的是我真遇到了!!,忙活了半天,除了一身汗,终于解决了,具体的问题就是,终端运行完全没问题,但是一到python的IDLE就会报错,偶然机会我试着用IDLE获取了一下系统变量,发现竟然获取不到 之前设置的环境变量ORACLE_HOME,LD_LIBRARY_PATH和DYLD_LIBRARY_PATH,那问题就找到了,又是mac的安全机制啊,限制了第三方工具获取系统的变量,那解决办法就是我们需要手动去添加了,添加方法如下:
 1  cd /Applications/Python\ 3.4/IDLE.app/Contents/Resources/(这个是系统安装的程序配置文件,进入此文件夹修改即可)
2 sudo nano idlemain.py(必须要用管理员权限,不然此文件无法修改)
3    在os.chdir(os.path.expanduser('~/Documents')) 这一行下面添加如下代码

        os.environ["ORACLE_HOME"]="/Users/zdh/Desktop/instantclient_11_2"
        os.environ["DYLD_LIBRARY_PATH"]="/Users/zdh/Desktop/instantclient_11_2"

        os.environ["LD_LIBRARY_PATH"]="/Users/zdh/Desktop/instantclient_11_2" 
4    保存更改, ctrl+x->Y->回车,退出idlemain.py的编辑状态
即我们去手动给他配置上环境变量,具体的路径请查看自己的安放目录。
做完上面的工作,用python的IDLE应该也不会报错了
最后,还有一个问题就是在python获取的sql结果会出现乱码问题,同样,这也需要给环境变量设置字符集,我们的oracle11g所用的字符集是gbk中文字符,所以同样需要设置 
idlemain.py文件。在同样的位置,添加如下代码
os.environ['NLS_LANG'] = 'American_America.ZHS16GBK' 
终于完成了,是不是一身汗?
如有问题,可以咨询我,qq与空间同号。最后,给大家贴一些参考网址,祝君顺利~
http://www.jianshu.com/p/1f584f1e7546
http://blog.csdn.net/ys_zhang/article/details/71393711
http://blog.csdn.net/lymm000/article/details/68925683
http://blog.csdn.net/q1241580040/article/details/48747569  

Mac10.12下Python3.4调用oracle的更多相关文章

  1. java下实现调用oracle的存储过程和函数

    在Oracle下创建一个test的账户,然后 1.创建表:STOCK_PRICES --创建表格 CREATE TABLE STOCK_PRICES( RIC VARCHAR() PRIMARY KE ...

  2. oracle学习笔记1:windows下oracle数据库安装及.net调用oracle数据库

    1.下载32位或64位oracle数据库并且安装,安装时可以选择安装数据库实例或者不安装,如果不安装的话之后可以用Database Configuration Assistant(DBCA) 通过向导 ...

  3. linux下python3调用c代码或者python3调用c++代码

    前几篇的blog都是为了这个实验做基础,先说 原因是python调用数据库150w条数据22s,然后处理数据,其实就2个简单的for循环,65s 需求: 1. python调用c++函数 2. c++ ...

  4. 【学习】java下实现调用oracle的存储过程和函数

    在oracle下创建一个test的账户,然后按一下步骤执行: 1.创建表:STOCK_PRICES --创建表格CREATETABLE STOCK_PRICES( RIC VARCHAR(6) PRI ...

  5. RedHat 6.7 Enterprise x64环境下使用RHCS部署Oracle 11g R2双机双实例HA

     环境 软硬件环境 硬件环境: 浪潮英信服务器NF570M3两台,华为OceanStor 18500存储一台,以太网交换机两台,光纤交换机两台. 软件环境: 操作系统:Redhat Enterpris ...

  6. RedHat 6.7 Enterprise x64环境下使用RHCS部署Oracle 11g R2双机HA

    环境 软硬件环境 硬件环境: 浪潮英信服务器NF570M3两台,华为OceanStor 18500存储一台,以太网交换机两台,光纤交换机两台. 软件环境: 操作系统:Redhat Enterprise ...

  7. mac10.9下eclipse的storm开发环境搭建

    --------------------------------------- 博文作者:迦壹 博客地址:http://idoall.org/home.php?mod=space&uid=1& ...

  8. Oracle创建表语句(Create table)语法详解及示例、、 C# 调用Oracle 存储过程返回数据集 实例

    Oracle创建表语句(Create table)语法详解及示例 2010-06-28 13:59:13|  分类: Oracle PL/SQL|字号 订阅 创建表(Create table)语法详解 ...

  9. python3.5连接oracle数据及数据查询

    今天心血来潮研究下用python连接oracle数据库,看了一下demo,本以为很简单,从操作到成功还是有点坎坷,这里分享给大家,希望为后面学习的童鞋铺路. 一.首先按照cx_Oracle 二:在py ...

随机推荐

  1. Android Studio Run项目出现Failure [INSTALL_FAILED_TEST_ONLY]

    同名掘金博文:https://juejin.im/post/5c2e0c496fb9a049a711f09a 运行环境: AS 版 本:Android Studio 3.2.1 手机型号:vivo Y ...

  2. Python json序列化

    Python内置的json模块提供了非常完善的对象到JSON格式的转换.废话不多说,我们先看看如何把Python对象变成一个JSON: d = dict(name='Kaven', age=17, s ...

  3. 设计模式之行为类模式PK

    行为类模式包括: 责任链模式 命令模式 解释器模式 迭代器模式 中介者模式 备忘录模式 观察者模式 状态模式 策略模式 模板方法模式 访问者模式 行为型模式涉及到算法和对象间职责的分配 行为类模式关注 ...

  4. Django Admin管理入门

    Django最强大的部分之一是自动管理界面.它从模型中读取元数据,以提供快速,以模型为中心的界面,受信任的用户可以在其中管理您网站上的内容.管理员的推荐用途仅限于组织的内部管理工具.它不是用于构建整个 ...

  5. Vue.js 学习笔记 第3章 计算属性

    本篇目录: 3.1 什么是计算属性 3.2 计算属性用法 3.3 计算属性缓存 模板内容的表达式常用语简单的运算,当其过长或逻辑复杂时,会难以维护,本章的计算属性就是用于解决该问题的. 3.1 什么是 ...

  6. Android路由框架-ARouter详解

    文章大纲 一.页面路由基本介绍1.什么是页面路由2.为什么要使用页面路由二.页面路由框架ARouter介绍1.常用功能介绍2.常见应用场景三.源码下载四.参考文章   一.页面路由基本介绍 1.什么是 ...

  7. 【Matlab&Mathematica】对三维空间上的点进行椭圆拟合

    问题是这样:比如有一个地心惯性系的轨道,然后从轨道上取了几个点,问能不能根据这几个点把轨道还原了? 当然,如果知道轨道这几个点的速度的情况下,根据轨道六根数也是能计算轨道的,不过真近点角是随时间变动的 ...

  8. MySQL读取Binlog日志常见的3种错误

    1. mysqlbinlog: [ERROR] unknown variable 'default-character-set=utf8mb4' 当我们在my.cnf中添加default-charac ...

  9. postgres的使用命令

    1.更新源 yum install https://download.postgresql.org/pub/repos/yum/10/redhat/rhel-7-x86_64/pgdg-centos1 ...

  10. Web地图呈现原理

    地图投影 对于接触互联网地图的同学来说,最开始接触的恐怕就是坐标转换的过程了.由于地球是个近似椭球的形状,有各种各样的椭球模型来模拟地球,最著名的也就是GPS系统使用的WGS84椭球了.但是这些椭球体 ...