在 Django Admin 中实现字段智能搜索

Implement field wise searching in Django Admin

我正在使用 Django 2.0

我必须添加功能来从具有不同列的不同输入字段的模型中搜索字段。

我从 medium.com 开始关注 this tutorial 并像

一样实施了它

models.py

class WallmartRecord(models.Model):
    name = models.CharField(max_length=250)
    upc = models.CharField(max_length=100)
    price = models.CharField(max_length=100)
    category = models.CharField(max_length=250)

    class Meta:
        db_table = 'wallmart_records'

    def __str__(self):
        return self.name

admin.py

class InputFilter(admin.SimpleListFilter):
    template = 'admin/input_filter.html'

    def queryset(self, request, queryset):
        pass

    def lookups(self, request, model_admin):
        return ((),)

    def choices(self, changelist):
        # Grab only the "all" option.
        all_choice = next(super().choices(changelist))
        all_choice['query_parts'] = (
            (k, v)
            for k, v in changelist.get_filters_params().items()
            if k != self.parameter_name
        )
        yield all_choice


class WallmartNameFilter(InputFilter):
    parameter_name = 'name'
    title = _('Name')

    def queryset(self, request, queryset):
        if self.value() is not None:
            name = self.value()

            return queryset.filter(
                name=name
            )


@admin.register(WallmartRecord)
class WallmartRecordAdmin(admin.ModelAdmin):
    list_filter = [
        'WallmartNameFilter',
        'not_exists_in_amazon',
        'arbitrase_generated'
    ]

但这是错误的

SystemCheckError: System check identified some issues:

ERRORS:
<class 'arbitrase.admin.WallmartRecordAdmin'>: (admin.E116) The value of 'list_filter[0]' refers to 'WallmartNameFilter', which does not refer to a Field.

在 list_filter 中,您必须为自定义过滤器提供 class 名称。

list_filter = [YourFilterClass]

不要以字符串形式给出。