Decorated function in Python always returns None(Python中的修饰函数始终返回NONE)
本文介绍了Python中的修饰函数始终返回NONE的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我对Python中的装饰符有一个奇怪的问题。基本上,我试图包装一个函数,这样它就可以为每个请求创建和删除游标(不要问--这只是一个示例,对于演示这个问题很有用!)我还有其他打算)。
这里有一个示例:
class DB(object):
"""Our DB methods and connections"""
def __init__(self):
self.con = oursql.connect(host=host, user=user, passwd=passwd,
port=port, db=db)
self.cursor = None
def __del__(self):
self.con.close()
def wrapper(func):
"""Wrapper for our database methods"""
def _exec(*args):
"""Wherein the wrapping takes place"""
db.cursor = db.con.cursor()
func(*args)
db.cursor.close()
return _exec
@wrapper
def get_tables(db):
"""Returns a list of all tables in the database"""
results = []
db.cursor.execute('show tables')
tables = db.cursor.fetchall()
for table in tables:
results.append(table[0])
print results
return results
if __name__ == '__main__':
db = DB()
print get_tables(db)
这是可行的,但我从包装函数得到的结果仅返回None:
[list of tables from "print results" goes in here]
None <- returned by the "print get_tables(db)" line
推荐答案
您忽略了包装函数的返回值:
db.cursor = db.con.cursor()
func(*args)
db.cursor.close()
在这里,您的函数以没有显式返回值结束,所以Python给您的是缺省值None
。
您想要捕获返回值并返回:
db.cursor = db.con.cursor()
retval = func(*args)
db.cursor.close()
return retval
您可以在此处使用try:
/finally
来确保即使引发异常也关闭游标;这也简化了代码,因为finally
套件总是被执行,即使在try
块中返回:
db.cursor = db.con.cursor()
try:
return func(*args)
finally:
db.cursor.close()
另一种选择是使用游标作为上下文管理器;在这种情况下,任何事务也将自动为您提交;在异常情况下,事务将回滚。在这两种情况下,当上下文退出时,游标也将关闭:
with db.con.cursor() as db.cursor:
return func(*args)
请参阅我们的SQL文档中的cursors as context managers。
这篇关于Python中的修饰函数始终返回NONE的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:Python中的修饰函数始终返回NONE


基础教程推荐
猜你喜欢
- 使用大型矩阵时禁止 Pycharm 输出中的自动换行符 2022-01-01
- Plotly:如何设置绘图图形的样式,使其不显示缺失日期的间隙? 2022-01-01
- 修改列表中的数据帧不起作用 2022-01-01
- 求两个直方图的卷积 2022-01-01
- PermissionError: pip 从 8.1.1 升级到 8.1.2 2022-01-01
- 包装空间模型 2022-01-01
- 无法导入 Pytorch [WinError 126] 找不到指定的模块 2022-01-01
- 在同一图形上绘制Bokeh的烛台和音量条 2022-01-01
- 在Python中从Azure BLOB存储中读取文件 2022-01-01
- PANDA VALUE_COUNTS包含GROUP BY之前的所有值 2022-01-01