我试图使用pyobdc从IBM Series服务器(以前是AS400)中提取数据。我正在使用OBDC数据源管理员和iSeries Access ODBC驱动程序。以下是代码:
import pyodbc
conn = pyodbc.connect('DRIVER={iSeries Access ODBC Driver};system=SERVER;UID=USER;PWD=PASS;unicode_results=True')
conn.setencoding('utf-8')
c1=conn.cursor()
c1.execute("""select TEST from TESTER.ITEMTEST where TEST='005911'""")
<pyodbc.Cursor object at 0x02A1F460>
rows = c1.fetchall()
print(rows[0])这是返回的内容:
(B‘\xf0\xf5\xf9\xf1\xf0 1@)
据我所读,这是一个pyodbc.Row对象。我到处搜索互联网,找不到任何解决问题的方法。
我们内部的一位系统开发人员说,也许OBDC管理员中有某种设置是我需要更改的,但是所有的设置似乎都是正确的。
下面是OBDC管理员的一些截图,以及我如何设置驱动程序:
是否有方法将pyodbc.Row对象转换为数据库中包含的实际值?或者我还遗漏了什么?
我试过:
rows[0].TEST它仍然返回一个pyodbc.Row对象。我要做的就是返回从服务器中检索到的实际值,而不是pyodbc.Row对象。
当我使用:
c1.description我得到:
(('TEST', <class 'bytearray'>, None, 15, 15, 0, False),)我应该得到的实际价值是: 005911
发布于 2020-07-23 19:49:49
我换了连接线,它修好了所有的东西。我要补充的是: TRANSLATE=1
conn = pyodbc.connect('DRIVER={iSeries Access ODBC Driver};system=SERVER;TRANSLATE=1;UID=USER;PWD=PASS')https://stackoverflow.com/questions/63055290
复制相似问题