如何在pyodbc下将datetime.time返回类型更改为字符串



我已经将现有大型Python 2项目的代码库从pymssql移动到pyodbc。移动很容易,一切都构建并且运行良好,除了pyodbc返回类型为datetime.time的SQL Server列,其中pymssql(以及PostgreSQL本机驱动程序(返回字符串。

意思是,我收到一个datetime.time(11, 54, 13, 161000)对象而不是11:54:13.161000。有什么方法可以在不诉诸某种存储过程的情况下全局更改此行为?处理返回的对象而不是返回的字符串将涉及几天的重构和测试。

您可以使用 pyodbc 输出转换器函数来捕获从 SQL Server 返回的 TIME 值,并将它们格式化为字符串。

以前:

import pyodbc
cnxn = pyodbc.connect('DSN=SQLmyDb;', autocommit=True)
crsr = cnxn.cursor()
rtn = crsr.execute("SELECT CAST('11:54:13.161' AS TIME)").fetchval()
print(repr(rtn))  # datetime.time(11, 54, 13, 161000)
crsr.close()
cnxn.close()

后:

import pyodbc
import struct

def time_as_string(raw_bytes):
    tup = struct.unpack("<4hI", raw_bytes)  # e.g., (11, 54, 13, 0, 161000000)
    tweaked = [tup[i] // 100 if i == 4 else tup[i] for i in [0, 1, 2, 4]]
    return "{:02d}:{:02d}:{:02d}.{:07d}".format(*tweaked)

cnxn = pyodbc.connect('DSN=SQLmyDb;', autocommit=True)
cnxn.add_output_converter(pyodbc.SQL_SS_TIME2, time_as_string)
crsr = cnxn.cursor()
rtn = crsr.execute("SELECT CAST('11:54:13.161' AS TIME)").fetchval()
print(repr(rtn))  # '11:54:13.1610000'
crsr.close()
cnxn.close()

相关内容

最新更新