django autofill manytomany字段在admin中

时间:2012-07-01 16:26:44

标签: python django django-models django-admin

美好的一天,不久前,与Django合作。 遇到以下问题。

有两种型号

class Product(models.Model):
    productID       = models.AutoField(primary_key=True)
    brandID         = models.ForeignKey(Brand, verbose_name=u'Бренд')
    categoryID      = models.ForeignKey(Category, verbose_name=u'Категория')
    productPhotos   = models.ManyToManyField("ProductPhoto", verbose_name = "Фотографии товара", related_name="photos", blank=True)

class ProductPhoto(models.Model):
    productPhotoID      = models.AutoField(primary_key=True)
    productID           = models.ForeignKey(Product)
    imageFile           = models.FileField(u'Путь к изображение', upload_to=makeUploadPath)
    dateModified        = models.DateField(auto_now=True)

对于管理员,请使用以下TabularInline

class ProductPhotoInline(admin.TabularInline):
    model = ProductPhoto
    verbose_name = u"Фото"
    verbose_name_plural = u"Фотографии"

class ProductAdmin(admin.ModelAdmin):
    list_display = ('title')
    search_fields = ...
    fieldsets = ...
    )
    inlines = [ ProductPhotoInline, ]

在表ProdcutPhoto productId字段中添加产品时出现的问题已填充,表Products productPhotos中的字段为空。如何最好地填补这两个领域。

1 个答案:

答案 0 :(得分:0)

你应该删除productPhotos ManyToMany字段,它是多余的。如果每张照片只附加到一个产品上,那么就可以使用productID ForeignKey。

要从产品实例访问照片,您可以使用productphoto_set,例如

product = Product.objects.get(pk=1)
photos = product.productphoto_set.all()