“可选功能未实现(106)(SQLBindParameter)”与pyodbc出错

时间:2013-11-27 10:39:29

标签: python ms-access-2010 pyodbc pypyodbc

我正在努力想出这个问题。我第一次使用Python,并尝试将从twitter收集的数据写入Access 2010数据库。

我正在使用的命令是:

cursor.execute('''insert into core_data(screen_name,retweet_count) values (?,?,)''', (sname,int(rcount)))

返回的错误消息是:

Traceback (most recent call last):  File "C:/Documents and Settings/Administrator/PycharmProjects/clientgauge/tw_scraper.py", line 44, in <module>
cursor.execute('''insert into core_data(screen_name,retweet_count) values (?,?,)''', (sname,int(rcount))) 
pyodbc.Error: ('HYC00', '[HYC00] [Microsoft][ODBC Microsoft Access Driver]Optional feature not implemented  (106) (SQLBindParameter)')

我尝试过将数据传递到数据库的各种排列。如果我删除int(rcount)条目,它将发布第一个值sname,没有任何问题。一旦我尝试传递多个参数,就会出现问题。

我有一种感觉,我错过了一些非常基本的东西,但是我找不到任何这样的例子,它实际上与我正在尝试的东西有类似的外观,而我正在尝试的并不困难。 ..user错误可能:))

非常感谢任何帮助。

干杯, 千电子伏

完整的代码是:

from twython import Twython
import pyodbc
ACCESS_DATABASE_FILE = 'C:\\data\\ClientGauge.accdb'
ODBC_CONN_STR = 'DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=%s;' %ACCESS_DATABASE_FILE
cnxn = pyodbc.connect(ODBC_CONN_STR, autocommit=True)
cursor = cnxn.cursor()
APP_KEY = '<removed>'
APP_SECRET = '<removed>'
# Authenticate on twitter using keys above
t = Twython(APP_KEY, APP_SECRET, oauth_version=2)
# Obtain new access token for this session
ACCESS_TOKEN = t.obtain_access_token()
# Authenticate using new access token
t = Twython(APP_KEY, access_token=ACCESS_TOKEN)
# Carry out search
search = t.search(q='<removed>', #**supply whatever query you want here**
         count=1, result_type='recent')
tweets = search['statuses']
for tweet in tweets:
sname=tweet['user']['screen_name']
rcount=int(tweet['retweet_count'])
fcount=tweet['favorite_count']
coord=tweet['coordinates']
tzone=tweet['user']['time_zone']
cdate=tweet['created_at']
htags=tweet['entities']['hashtags']
sql = "insert into core_data(screen_name,retweet_count,favourited_count) values (?,?,?)", (str(sname),rcount,fcount)
print(sql)
cursor.execute('''insert into core_data(screen_name,retweet_count) values (?,?)''', (sname,rcount))
cursor.commit()
cnxn.close()

我正在使用MS Access 2010,pyodbc-3.0.7.win32-py3.3.exe,Python 3.3&amp; PyCharm。

不要判断我的编码能力:) Python对我来说是新的。您将能够看到我最初尝试将INSERT语句设置为字符串(sql),并且我使用以下方法调用游标:

cursor.execute(sql)

不幸的是,这对我来说也不起作用!如果我用诸如1之类的数字替换第二个参数......它仍然不起作用。令人沮丧。

3 个答案:

答案 0 :(得分:6)

我对这个驱动程序和pyodbc有同样的错误,结果是将整数转换为浮点数解决了这个问题:

row = [1, 2, "foo"]
row = [float(x) if type(x) is int else x for x in row] #Convert all int items to floats
cursor.execute("insert into table1 (a,b,c) values (?,?,?)",row).commit()

答案 1 :(得分:3)

你的参数列表中有一个额外的逗号,搞砸了你。以下代码适用于Python 2.7:

import pyodbc
sname = 'Gord'
rcount = 3
cnxn = pyodbc.connect(
        'DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};' +
        'DBQ=C:\\Users\\Public\\Database1.accdb;')
cursor = cnxn.cursor()
sql = "insert into core_data(screen_name,retweet_count) values (?,?)"
params = (sname, int(rcount))
cursor.execute(sql, params)
cursor.commit()
cnxn.close()

编辑:

事实证明,当pyodbc在Python 3.x下运行时与Access ODBC交互时,有reported issue个整数参数。一种可能的解决方法是尝试下载并安装pypyodbc然后尝试此代码(在Python 3.5.2下适用于我):

import pypyodbc
sname = 'Gord'
rcount = 3
cnxn = pypyodbc.connect(
        'DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};' +
        'DBQ=C:\\Users\\Public\\Database1.accdb;')
cursor = cnxn.cursor()
sql = "insert into core_data(screen_name,retweet_count) values (?,?)"
params = (sname, rcount)
cursor.execute(sql, params)
cursor.commit()
cnxn.close()

答案 2 :(得分:0)

我遇到了同样的问题,但对我来说这与驱动程序配置有关。

我在 ODBC 驱动程序配置中启用了快速选择,我确认这是我收到此错误的原因。

发布此信息以防万一其他人修改了他们的驱动程序设置,并且建议的解决方案与我的情况不同。