6

我正在使用Django import_export在我的管理页面中实现 CSV 上传。现在我有一个模型,它包含一个外键列,但外键列对于每个导入只有一个值。因此,我希望允许用户从下拉列表中选择相关的模型实例,而不是强迫用户自己附加列。为了做到这一点,我需要自定义导入表单,这需要覆盖默认方法import_actionprocess_import,但到目前为止我的努力没有任何效果。这是我到目前为止所拥有的:

from django import forms
from import_export.forms import ImportForm  
from .models import MyModel, RelatedModel

class CustomImportForm(ImportForm):
    """Add a model choice field for a given model to the standard form."""
    appended_instance = forms.ModelChoiceField(queryset=None)

    def __init__(self, choice_model, import_formats, *args, **kwargs):
        super(CustomImportForm, self).__init__(import_formats, *args, **kwargs)
        self.fields['appended_instance'].queryset = choice_model.objects.all()

@admin.register(MyModel)
class MyModelAdmin(ImportExportModelAdmin):
    resource_class = SomeResource


    def import_action(self, request, *args, **kwargs):
        super().import_action(self, request, *args, **kwargs)
        form = CustomImportForm(RelatedModel, 
                                import_formats,
                                request.POST or None,
                                request.FILES or None)

现在,当我进入导入页面时,我AttributeError MyModelAdmin has no attribute 'POST'在本地 vars 中看到,request object实际上是MyModelAdmin类,我相信这不是它应该是的。

4

3 回答 3

2

避免重新实现import_action()or process_import(); 部分是因为它们是相当复杂和脆弱的方法,但更重要的是因为使用 Import/Export API 中现有的钩子有更简洁的方法。有关更多详细信息,请参阅此答案。

于 2018-12-05T23:06:30.137 回答
1

我知道,这是一篇旧帖子,但我在查看如何覆盖 import_action 时遇到了这个问题。你的错误在这里: super().import_action(self, request, *args, **kwargs)

你应该在没有自我的情况下调用它:

super().import_action(request, *args, **kwargs)

或对于较旧的python:

super(MyModelAdmin, self).import_action(request, *args, **kwargs)

于 2016-06-29T10:53:47.377 回答
0
    def import_action(self, request, *args, **kwargs):
       response = super(MyModelAdmin, self).import_action(request, *args, **kwargs)
       context = response.context_data
       import_formats = self.get_import_formats()
       context['form'] = CustomImportForm(RelatedModel, import_formats, request.POST or None, request.FILES or None)
       return TemplateResponse(request, [self.import_template_name], context)
于 2018-02-23T14:23:37.137 回答