MacOS M1 Python 使用Oracle数据库|安装Oracle 客户端|安装cx_oracle包
安装rosetta2(可选)
这是一个将x86程序翻译至m1的软件
直接安装即可
1 | /usr/sbin/softwareupdate --install-rosetta |
安装x86_64 brew(可选)
为了安装其他x86架构的软件方便,此次不安装也可以
ARM版brew安装
使用命令安装即可
1
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
X86版本 brew
在命令前增加arch -x86_64
1 | arch -x86_64 /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)" |
多版本共存
在 ~/.zprofile
文件中添加如下内容
1 | alias abrew='arch -arm64 /opt/homebrew/bin/brew' |
其中,abrew
和ibrew
这两个名字可变,这样一个是运行arm版本,一个是运行x86版本
执行source ~/.zprofile
在当前终端中生效
安装x86_64 Anaconda
多版本的anaconda共存初步尝试后会有问题,如果之前安装过arm版本的anaconda,如无特殊需求,最好卸载,直接安装x86版本。
如果之前配置过复杂的python环境,谨慎操作
安装
下载x86版本的安装文件
1
wget -o https://repo.anaconda.com/archive/Anaconda3-2022.05-MacOSX-x86_64.sh
直接安装,安装开始的时候会有提醒安装的是x86版本,直接确认即可
创建python环境
1 | conda create -n py37_x86 python=3.7 |
arm版本能够安装的python版本最低是3.8
只要能创建3.7的环境就说明安装应该没问题
安装cx_oracle及oracle client
安装cx_oracle
激活python环境
1
conda activate py37_x86
使用pip安装
1
pip install cx_oracle
安装后无法直接使用,需要下载oracle官网上的一些安装包
安装oracle client
访问下载页:https://www.oracle.com/database/technologies/instant-client/macos-intel-x86-downloads.html
下载Basic Package (ZIP)、SQL*Plus Package (ZIP)、SDK Package (ZIP)三个包
将这三个包解压至相同路径,解压完成后就是这些文件
配置环境变量,编辑
~/.zprofile
,根据实际情况修改自己的路径1
2
3
4
5export PATH=/Users/halfcoke/oracle_client/instantclient_19_8:$PATH
export ORACLE_HOME=/Users/halfcoke/oracle_client/instantclient_19_8
export DYLD_LIBRARY_PATH=/Users/halfcoke/oracle_client/instantclient_19_8
export OCI_LIB_DIR=/Users/halfcoke/oracle_client/instantclient_19_8
export OCI_INC_DIR=/Users/halfcoke/oracle_client/instantclient_19_8/sdk/include
在这之后就可以在python中导入cx_oracle使用了,首次运行会弹出“macOS 无法验证此app”的问题
打开系统偏好设置>安全性与隐私>通用,这时候会有“仍然允许”的按钮,点击即可,应该会有多个,多点几次就可以了,下次运行不会再出现了。
图片是在网上找的图,应用名称可能会不一样,用作示意。