adodbapi的bug?

在Python下操作Access数据库,以前一直都是用win32com创建ADO对象,然后操作,最近看到一个adodbapi模块,基于win32com,符合Python DB API 2.0接口,看着不错,就试了试。

在使用的时候发现一个问题。当我用adodbapi.connect打开一个Access数据库文件,进行操作,关闭,然后再次调用adodbapi.connect打开同一数据库的时候,会抛adodbapi.adodbapi.InterfaceError异常,异常信息如下:

...

  File "D:/Python25/lib/site-packages/adodbapi/adodbapi.py", line 253, in connect
    raise InterfaceError #Probably COM Error
adodbapi.adodbapi.InterfaceError

看来一下代码,这部分代码是

     try :
        conn
= Dispatch( ' ADODB.Connection ' )
        
if  win32:
            pythoncom.CoInitialize()                 
# v2.1 Paj
     except :
        
raise  InterfaceError  # Probably COM Error

想了想,觉得应该先CoInitialize,就修改了一下

     try :
        
if  win32:
            pythoncom.CoInitialize()                 
# v2.1 Paj
        conn = Dispatch( ' ADODB.Connection ' )
    
except :
        
raise  InterfaceError  # Probably COM Error

果然就OK了。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值