我编写了一堆辅助函数来包装插入和选择等常用函数。下面包含的只是其中一个包装器...我似乎无法弄清楚它为什么不起作用。
我怀疑它与包装器有关:
from collections import Mapping
import sqlite3
def counter(func):
def wrapper(*args, **kwargs):
wrapper.count = wrapper.count + 1
wrapper.count = 0
return wrapper
@counter
def insert(val, cursor, table="reuters_word_list", logfile="queries.log"):
if val:
if isinstance(val, (basestring, Mapping)):
val='\"'+val+'\"'
query = ("insert into %s values (?);" % 'tablename', val)
if logfile:
to_logfile(query + '\n', logfile)
cursor.execute(query)
if __name__ == '__main__':
connection = sqlite3.connect('andthensome.db')
cursor = connection.cursor()
cursor.execute("create table wordlist (word text);")
insert("foo", cursor)
connection.commit()
cursor.execute("select * from wordlist;")
print cursor.fetchall()
cursor.close()
答案 0 :(得分:6)
您的计数器装饰者实际上从未调用 func。
尝试
def counter(func):
def wrapper(*args, **kwargs):
wrapper.count += 1
return func(*args, **kwargs) # <- this line is important!!
wrapper.count = 0
return wrapper