python链接DB2数据库相关问题(离线安装,pandas读取等)

python链接DB2数据库相关问题(离线安装,pandas链接等)

由于单位内网无法链接网络,所以在安装完anaconda后,只能手动离线安装db2的包:ibm_db
一、离线安装ibm_db:
参考https://blog.csdn.net/somezz/article/details/80745695
主要有一个坑的地方需要注意:
1.在下载ntx64_odbc_cli.zip解压后将clidriver文件夹放入setup.py同级文件夹后,执行setup.py安装后,在spyder中import ibm_db 还是会报错ImportError: DLL load failed: 找不到指定的模块
解决办法:setup.py执行完成后安装目录下会新生成一个ibm_db-3.0.1.egg-info文件夹,把上一步解压的clidriver放入这个文件夹即可;亲测成功;

二、使用pandas读取DB2数据
这时你按照网上的教程,import ibm_db 后建立connect,兴致勃勃的sql=’…’
然后df=pd.read_sql(sql,conn)时会发现报错has no attribuute ‘cursor’ 这个ibm_db链接不能创建pandas所需要的游标。
原因:个人理解可能是pandas使用的conn链接可能需要支持python的DB-API规范,而ibm_db创建的connect并不支持导致出错(小白理解,有错误请指出)

解决办法1:在你安装完ibm_db包后,其实附带另一个支持pandas读取数据的方法,那就是ibm_db_dbi,只需import ibm_db_dbi,即可实现pandas读取db2数据返回dataframe数据

import ibm_db_dbi
import pandas as pd

conn = ibm_db_dbi.connect("database=***;hostname=你的数据库ip地址;port=端口号;protocol=通信协议(tcp/ip);UID=用户;PWD=密码","","")
sql = """select * from a_table"""
df = pd.read_sql(sql,conn)

解决方法2:使用ibm_db_sa+SQLAlchemy
前提:需要安装ibm_db_sa

from SQLAlchemy  import create_engine
import ibm_db_sa
import pandas as pd

e = create_engine("db2+ibm_db://user:pass@host[:port]/database")
df = pd.read_sql(sql,create_engine)
  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这是一个比较复杂的问题,需要分步骤来回答。 1. 首先,你需要安装相应的 Python 模块来读取 Excel 文件。比较常用的模块是 Pandas 和 Openpyxl。这里以 Pandas 为例,你可以使用 `pandas.read_excel()` 函数来读取 Excel 文件中的数据,例如: ```python import pandas as pd df = pd.read_excel('your_file.xlsx') ``` 2. 接下来,你需要根据读取到的数据来确定连接的类型。一种简单的方法是在 Excel 文件中添加一个列,来标识每行数据对应的连接类型。例如,你可以在表格中添加一个名为 `db_type` 的列,用来标识每行数据所属的数据库类型,取值为 `oracle`、`mysql` 或者 `db2`。 3. 然后,你可以使用 Python 中相应的数据库模块来连接数据库并执行查询。不同类型的数据库需要使用不同的模块,比如: - Oracle:cx_Oracle - MySQL:mysql-connector-python - DB2:ibm_db 以 Oracle 数据库为例,你可以使用以下代码来连接: ```python import cx_Oracle # 连接数据库 conn = cx_Oracle.connect('username/password@host:port/service_name') # 执行查询 cursor = conn.cursor() cursor.execute('SELECT * FROM your_table') result = cursor.fetchall() # 关闭连接 cursor.close() conn.close() ``` 需要注意的是,不同类型的数据库连接参数可能会有所不同,具体可以查看相应模块的文档。 4. 最后,你可以将查询结果保存到 Excel 文件中。可以使用 Pandas 的 `to_excel()` 函数来实现: ```python df_result = pd.DataFrame(result) df_result.to_excel('result.xlsx', index=False, header=False) ``` 其中,`index=False` 和 `header=False` 参数用来去除索引和列名。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值