Создание моделей из json feed в Джанго - PullRequest
0 голосов
/ 09 мая 2018

Я создаю приложение django для просмотра доступных продуктов на разных рынках. Я получаю данные для своих моделей из фида URL JSON, но я не уверен в том, как лучше всего превратить эти данные в модели, поскольку фид для одного рынка может содержать более 50 тыс. Элементов.

Модели - не стесняйтесь предлагать какие-либо улучшения этих

# Details of a sellable products
class Product(models.Model):
    item = models.IntegerField(primary_key=True, auto_created=False)
    name = models.CharField(max_length=40)

# Market where products can be bought, some markets will cater to multiple suburbs.
class Market(models.Model):
    id = models.IntegerField(primary_key=True, auto_created=True)
    name = models.CharField(max_length=40)

# Nearby suburbs can share the one market
class Suburb(models.Model):
    name = models.CharField(max_length=30)
    market = models.ForeignKey(Market, on_delete=models.SET_NULL, null=True)

# Actual product for sale
class ProductForSale(models.Model):
    sale = models.IntegerField(primary_key=True)
    product = models.ForeignKey(Product, on_delete=models.SET_NULL, null=True)
    cost = models.IntegerField(default=1)
    owner = models.CharField(max_length=30)
    quantity = models.IntegerField(default=1)
    market = models.ForeignKey(Market,on_delete=models.SET_NULL, null=True )

Пример рынка товаров

"market_products": [
    {
        "id":11654,
        "item":123,
        "owner":"Bob",
        "suburb":"Springvale",
        "cost":3,
        "quantity":1,

    },
    {
        "id":11655,
        "item":123,
        "owner":"Sarah",
        "suburb":"Sunnyville",
        "cost":5,
        "quantity":2,

    },

Вот как я пытаюсь заполнить свои модели ProductForSale - я не знаю, является ли это правильным подходом для Product FK или как связать пригород с его Market FK

    markets = Market.objects.all()
    for market in markets:
        url = "jsonurl"
        response = urllib.request.urlopen(url)
        data = json.loads(response.read())
        for entry in data['market_products']:
                new_product_sale = ProductForSale.objects.create(
                    product = Product.objects.get(item=entry['item']),
                    cost = entry['cost'],
                    owner = entry['owner'],
                    quantity = entry['quantity']
                )
                new_product_sale.save()

Есть ли момент, когда я должен создать отдельную модель для каждого рынка товаров, или это нормально, чтобы поместить их всех в одну модель?

1 Ответ

0 голосов
/ 15 июня 2018

Закончено использование одной модели для всех рыночных продуктов, пока что не возникало никаких проблем.

...