我正在开发我的 python 库的几个模块,通过 IPython 进行大部分测试。
每当我尝试重新加载(deep_reload)使用 sqlalchemy 的模块时,重新加载会引发异常并且无法重新加载模块(我必须启动新内核并重新导入)。更具体地说,任何导入我的 sqlalchemy 声明性模型的模块。
回溯很长,所以我现在总结一下,如果需要,可以提供更多。
在异常之前,StdOUT 读取(这只是底部):
Reloading pysqlite2
Reloading sqlalchemy.dialects.sqlite.sqlite3
Reloading sqlite3
Reloading sqlite3.dbapi2
Reloading sqlite3.datetime
Reloading sqlite3.time
Reloading sqlite3._sqlite3
Reloading _sqlite3
然后抛出异常,这里是回溯的最新条目:
\pydir\lib\site-packages\sqlalchemy-0.7.9-py2.7.egg\sqlalchemy\util\_collections.pyc in __setitem__(self, object, value)
697 if oid not in self._weakrefs:
698 self._weakrefs[oid] = self._ref(object)
--> 699 weakref.WeakKeyDictionary.__setitem__(self, object, value)
700
701 def __delitem__(self, object):
TypeError: unbound method __setitem__() must be called with WeakKeyDictionary instance as first argument (got WeakIdentityMapping instance instead)
编辑:问题更新
调用 reload 时,我开始根据回溯堆栈顶部的模块(上例中的“_sqlite3”)添加排除项。
我发现我一直收到相同的错误,只是它来自一个新模块('pysqlite2','sqlite3')。并且在每种情况下,在回溯中总是有更高的 SqlAlchemy,更具体地说,是“sqlalchemy.orm.mapper”。
在定义我的模型 orm 类时,我定义了我的 orm 类,并在导入时直接从模块将它们添加到会话中。解决方案是将这几行包装在一个不应在导入时执行的函数中。似乎可以修复。
我认为这只是一些懒惰的编码终于赶上了我的一个例子。