Django: Загрузка нескольких каталогов изображений одновременно

В моем проекте Django я хочу загружать массовые изображения для продуктов из каталога каталогов. Каждый каталог назван по SKU для продукта. В каждом каталоге может быть несколько изображений, а может и не быть. Как я могу достичь этой функциональности?

Мои модели:

class Product(models.Model):
    sku = models.CharField('SKU', max_length = 200)
    name = models.CharField('Name', max_length = 1000)
    price = models.CharField('Price', max_length = 200)
    quantity = models.CharField('Quantity', max_length = 200)

    class Meta:
        verbose_name = 'Product'
        verbose_name_plural = 'Products'

    def __str__(self):
        return self.name

class Image(models.Model):
    product = models.ForeignKey(Product, on_delete=models.CASCADE, verbose_name='product_image')
    image = models.ImageField(upload_to='images/')

    class Meta:
        verbose_name = 'Image'
        verbose_name_plural = 'Images'

    def __str__(self):
        return str(self.image)

Мой urls.py

from django.urls import path
from . import views

urlpatterns = [

    path('products/', views.products, name="products"),
    path('products_import/', views.products_import, name="products_import"),    
]

Мой views.py

def products_import(request):
    heading = 'Upload Products'
    info = '''This importer will import the following fields: sku, name, price, quantity from a csv file.'''
    if request.method == 'POST':
        paramFile = io.TextIOWrapper(request.FILES['file'].file, encoding='latin-1')
        product = csv.DictReader(paramFile)
        list_of_dict = list(product)
        objs = [
            Product(
                sku=row['sku'],
                name=row['name'],
                price=row['price'],
                quantity=row['quantity'],
         )
         for row in list_of_dict
        ]
        record_count = len(list_of_dict)
        try:
            msg = Product.objects.bulk_create(objs)
            messages.success(request, str(record_count) + ' records were uploaded.')
            return redirect('products_import')
        except Exception as e:
            error_message = 'Error While Importing Data: ',e
            messages.error(request, error_message, e)    
            return redirect('products_import')
    context = {'heading': heading, 'info': info}
    return render(request, 'coreapp/product/products_import.html', context)

Я могу загрузить большое количество товаров, используя нижеприведенный CSV и вышеприведенный вид.

enter image description here

Внутри каждой папки SKU есть несколько изображений.

enter image description here

Я хочу загрузить изображения из папок сразу и связать их с соответствующими SKU. Как я могу этого добиться? Любое руководство будет высоко оценено.

NB: Я могу загрузить одно изображение для продукта. Если мы хотим загрузить тысячи продуктов и связанных с ними изображений, загрузка одного изображения не является целесообразным решением.

Скопируйте & вставьте изображения в каталог MEDIA_ROOT + '/images' вручную.

Используйте пользовательскую команду вместо представления. Это будет более полезно и удобно в таких случаях. Вот ссылка как это сделать.

Основная часть команды выглядит следующим образом.

import os
from django.conf.settings import MEDIA_ROOT


...

for data in products_data:
    product = Product.objects.create(sku=data['sku'], ...)
    images = os.listdir(os.path.join(MEDIA_ROOT, 'images'))
    for image in images:
        Image.objects.create(
            product=product,
            image=f'images/{product.sku}/image'
        )

Убедитесь, что в каталоге images нет ни одного файла, кроме images.

Вернуться на верх