目前看到的集中方式 odbc 或 IfxPy 均需要配置环境变量,依赖系统的informix驱动,打包成的exe也不带驱动
(mysql打的包带驱动可直接运行)
相对而言 IfxPy 更好点,只配置下 Informix Client SDK 即可
下载sdk,安装 IfxPy 见下文 链接1的博客(是linux的)
另外提供个windows64位的,如果需要linux自行去官网下载,需要注册账号
官网下载地址:https://www-01.ibm.com/marketing/iwm/iwm/web/pickUrxNew.do?source=ifxdl
链接:https://pan.baidu.com/s/1G9tfSWEgBWR3QMFxdjJuRg 提取码:xyln 复制这段内容后打开百度网盘手机App,操作更方便哦
如果是windows只需要如下配置即可,配置环境变量 LD_LIBRARY_PATH

特别注意,位数要匹配,比如32位的 python 要用32位sdk. 64位同理
特别注意,gbase8s或者8t等,以下2个参数必须的,根据实际的数据库的格式来调整
CLIENT_LOCALE=zh_cn.utf8;DB_LOCALE=zh_cn.GB18030-2000
代码如下:
import os
import sys
import IfxPy
#生成资源文件目录访问路径
import pyodbc
def resource_path(relative_path):
if getattr(sys, 'frozen', False): #是否Bundle Resource
base_path = sys._MEIPASS
else:
base_path = os.path.abspath(".")
return os.path.join(base_path, relative_path)
SERVER = "实例名"
DATABASE="库名"
HOST="ip地址"
PORT = 端口号
UID = "用户名"
PWD = "密码"
connectStr = "PROTOCOL=onsoctcp;SERVICE=%s;UID=%s;PWD=%s;DATABASE=%s;HOST=%s;SERVER=%s;" \
"CLIENT_LOCALE=zh_cn.utf8;DB_LOCALE=zh_cn.GB18030-2000"\
% (PORT,UID, PWD, DATABASE, HOST,SERVER )
connect=IfxPy.connect(connectStr, "", "")
# 查询数据
sql = "SELECT * FROM bblx"
data = ()
stmt = IfxPy.exec_immediate(connect, sql)
dictionary = IfxPy.fetch_assoc(stmt)
rc = 0
while dictionary != False:
rc += 1
print (dictionary)
dictionary = IfxPy.fetch_assoc(stmt)
# 关闭连接
# Free up memory used by result and then stmt too
IfxPy.free_result(stmt)
IfxPy.free_stmt(stmt)
IfxPy.close(connect)
#打带console的包时,使窗口不会闪一下关闭
os.system("pause")
参考文章:
链接1: https://www.cnblogs.com/yu121/p/14290846.html 链接2: https://github.com/OpenInformix/IfxPy/wiki |