将 django 升级到 1.7 后,我无法执行管理命令 update_index。
Traceback (most recent call last):
File "/opt/pycharm-3.4.1/helpers/pydev/pydevd.py", line 1733, in <module>
debugger.run(setup['file'], None, None)
File "/opt/pycharm-3.4.1/helpers/pydev/pydevd.py", line 1226, in run
pydev_imports.execfile(file, globals, locals) # execute the script
File "/home/tochium/projects/povary/manage.py", line 10, in <module>
execute_from_command_line(sys.argv)
File "/home/tochium/projects/povary/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 385, in execute_from_command_line
utility.execute()
File "/home/tochium/projects/povary/local/lib/python2.7/site-packages/django/core/management/__init__.py", line 377, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
File "/home/tochium/projects/povary/local/lib/python2.7/site-packages/django/core/management/base.py", line 288, in run_from_argv
self.execute(*args, **options.__dict__)
File "/home/tochium/projects/povary/local/lib/python2.7/site-packages/django/core/management/base.py", line 338, in execute
output = self.handle(*args, **options)
File "/home/tochium/projects/povary/src/django-haystack/haystack/management/commands/update_index.py", line 184, in handle
return super(Command, self).handle(*items, **options)
File "/home/tochium/projects/povary/local/lib/python2.7/site-packages/django/core/management/base.py", line 503, in handle
label_output = self.handle_label(label, **options)
File "/home/tochium/projects/povary/src/django-haystack/haystack/management/commands/update_index.py", line 189, in handle_label
self.update_backend(label, using)
File "/home/tochium/projects/povary/src/django-haystack/haystack/management/commands/update_index.py", line 234, in update_backend
do_update(backend, index, qs, start, end, total, self.verbosity)
File "/home/tochium/projects/povary/src/django-haystack/haystack/management/commands/update_index.py", line 89, in do_update
backend.update(index, current_qs)
File "/home/tochium/projects/povary/src/xapian-haystack/xapian_backend.py", line 355, in update
data = index.full_prepare(obj)
File "/home/tochium/projects/povary/src/django-haystack/haystack/indexes.py", line 207, in full_prepare
self.prepared_data = self.prepare(obj)
File "/home/tochium/projects/povary/src/django-haystack/haystack/indexes.py", line 198, in prepare
self.prepared_data[field.index_fieldname] = field.prepare(obj)
File "/home/tochium/projects/povary/src/django-haystack/haystack/fields.py", line 159, in prepare
return self.convert(super(CharField, self).prepare(obj))
File "/home/tochium/projects/povary/src/django-haystack/haystack/fields.py", line 106, in prepare
return current_object()
File "/home/tochium/projects/povary/local/lib/python2.7/site-packages/django/db/models/fields/related.py", line 839, in __call__
manager = getattr(self.model, kwargs.pop('manager'))
KeyError: u'manager'
我用python2.7.6,django 1.7,django-haystack 2.3.1,搜索引擎:xapian
我认为出现问题是因为 1.7 中的 django 将方法调用() 添加到 ManyRelatedManager 并且现在在文件 /haystack/fields.py 中触发了这种情况。
if callable(current_object):
return current_object()
但是在调用manager_name 应该定义,我们如何在适当的方法中看到
def __call__(self, **kwargs):
# We use **kwargs rather than a kwarg argument to enforce the
# `manager='manager_name'` syntax.
manager = getattr(self.model, kwargs.pop('manager'))
谢谢。