Django 管理员有很多选择

标签 django django-models django-admin

我有以下 models.pyadmin.py 文件。目的是允许在必要时为给定产品选择多个类别。

模型.py

class Product(models.Model):
    organization = models.ForeignKey(Organization)
    name = models.CharField(max_length=50)
    brief = models.CharField(max_length=100)
    descrip = models.TextField(max_length=1300)
    categories = models.ManyToManyField('Product_Category')

class Product_Category(models.Model):
    cats = {"AUT":"Automation", "PWA":"Personal Wealth Advisory", 
            "BCH":"Blockchain", "LOS":"Loan Origination", "FX":"Foreign Exchange"}
    choices = tuple((human, c) for human, c in cats.items())
    name = models.CharField(max_length=32, choices=choices)

admin.py

 from .models import Product, Product_Feature, Organization, Product_Category

class PFeatureInLine(admin.StackedInline):
    model = Product_Feature
    extra = 1

class ProductForm(forms.ModelForm):
    logo_file = forms.ImageField()

    def save(self, commit=True):
        logo_file = self.cleaned_data.get("logo_file", None)
        self.instance.logo = b64encode(logo_file.read()).decode("utf-8")
        return forms.BaseModelForm.save(self, commit=commit)

    class Meta():
        exclude = ["logo"]
        model = Product

class ProductAdmin(admin.ModelAdmin):
    form = ProductForm
    inlines = [PFeatureInLine,]

admin.site.register(Product, ProductAdmin)
admin.site.register(Organization)

当通过 admin 访问 Products 对象时,结果如下:

enter image description here

最佳答案

需要这样展示吗?

我建议你使用FilteredSelectMultiple:

from django import forms
from django.contrib import admin
from django.contrib.admin.widgets import FilteredSelectMultiple

from .models import Product, Product_Feature, Organization, Product_Category


class ProductForm(forms.ModelForm):
    logo_file = forms.ImageField()

    categories = forms.ModelMultipleChoiceField(
          queryset=Product_Category.objects.all(),
          required=False,
          widget=FilteredSelectMultiple(
              verbose_name=_('Categories'),
              is_stacked=False
          )
    )

    def __init__(self, *args, **kwargs):
        super(ProductForm, self).__init__(*args, **kwargs)

        if self.instance and self.instance.pk:
            self.fields['categories'].initial = self.instance.categories.all()

    def save(self, commit=True):
        logo_file = self.cleaned_data.get("logo_file", None)
        self.instance.logo = b64encode(logo_file.read()).decode("utf-8")
        return forms.BaseModelForm.save(self, commit=commit)

    class Meta:
        exclude = ['logo']
        model = Product


class ProductAdmin(admin.ModelAdmin):
    form = ProductForm
    inlines = [PFeatureInLine,]

关于Django 管理员有很多选择,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45265069/

相关文章:

python - 无法登录在 django 管理后端创建的 super 用户

python - 如何用Django模型数据库API实现Mysql操作UNHEX & HEX

django - 在 ModelAdmin 中添加代码片段

python - Django 1.7 从内联表单中删除添加按钮

python - 将 DJANGO_SETTINGS_MODULE 永久设置为 Windows 中的环境变量

python - 如何在 django 模板中转义 {{ 或 }}?

python - Django 模板 : how do I use key to access value?

python - 对没有迁移的应用程序的依赖 : %s"% key[0]) in the Django

python - 更新django中外键模型的数据

Django InlineModelAdmin 给出错误 'MediaDefiningClass' 对象不可迭代