web-dev-qa-db-ja.com

シードする方法Django project?-初期化のためにデータの束をプロジェクトに挿入します

私はDjangoで開発してきましたが、Djangoのデータベースにデータをシードする方法があるかどうか疑問に思っていました。

Ruby on Railsでは、seed.rbを使用し、コマンドラインで「rake db:seed」を実行します。

主な理由は、プロジェクトの初期化のためにステータス、タイプなどに関するデータをシードすることです。

似たようなものはありますか?

7
Axil

Railsと同様に、データベースをシードするオプションもあります。 管理コマンド を使用して行われます。いずれかのアプリで、次のフォルダー構造を使用します

<project>/<app>/management/commands/seed.py

これにより、python manage.py seed管理コマンドとして使用可能。私は個人的に次の構造に従います。

# <project>/<app>/management/commands/seed.py
from Django.core.management.base import BaseCommand
import random

# python manage.py seed --mode=refresh

""" Clear all data and creates addresses """
MODE_REFRESH = 'refresh'

""" Clear all data and do not create any object """
MODE_CLEAR = 'clear'

class Command(BaseCommand):
    help = "seed database for testing and development."

    def add_arguments(self, parser):
        parser.add_argument('--mode', type=str, help="Mode")

    def handle(self, *args, **options):
        self.stdout.write('seeding data...')
        run_seed(self, options['mode'])
        self.stdout.write('done.')


def clear_data():
    """Deletes all the table data"""
    logger.info("Delete Address instances")
    Address.objects.all().delete()


def create_address():
    """Creates an address object combining different elements from the list"""
    logger.info("Creating address")
    street_flats = ["#221 B", "#101 A", "#550I", "#420G", "#A13"]
    street_localities = ["Bakers Street", "Rajori Gardens", "Park Street", "MG Road", "Indiranagar"]
    pincodes = ["101234", "101232", "101231", "101236", "101239"]

    address = Address(
        street_flat=random.choice(street_flats),
        street_locality=random.choice(street_localities),
        pincode=random.choice(pincodes),
    )
    address.save()
    logger.info("{} address created.".format(address))
    return address

def run_seed(self, mode):
    """ Seed database based on mode

    :param mode: refresh / clear 
    :return:
    """
    # Clear data from tables
    clear_data()
    if mode == MODE_CLEAR:
        return

    # Creating 15 addresses
    for i in range(15):
        create_address()

上記の構造では、カスタムモードを追加し、それに応じてシードできます。また、追加の管理コマンド引数(たとえば、number_of_addressesを追加し、それを渡してシードを実行できます。コマンドはpython manage.py seed --mode=refresh --number_of_addresses=15)。

お役に立てれば。乾杯!

9
anurag

Django 2.2 docs によると、フィクスチャを作成することでデータベースをシードできます。既にデータを取得している場合にフィクスチャを作成する最も簡単な方法は、manage.py dumpdataコマンドを使用することです。または、手でフィクスチャを書くことができます。フィクスチャはJSON、XMLまたはYAMLとして記述できます。

ただし、例として、単純なPersonモデルのフィクスチャがJSONでどのように見えるかを以下に示します。

[
  {
    "model": "myapp.person",
    "pk": 1,
    "fields": {
      "first_name": "John",
      "last_name": "Snow"
    }
  },
  {
    "model": "myapp.person",
    "pk": 2,
    "fields": {
      "first_name": "Paul",
      "last_name": "McCartney"
    }
  }
]

そして、これがYAMLと同じフィクスチャです:

- model: myapp.person
  pk: 1
  fields:
    first_name: John
    last_name: Snow
- model: myapp.person
  pk: 2
  fields:
    first_name: Paul
    last_name: McCartney

このデータをアプリ内のフィクスチャディレクトリに保存します。

データの読み込みは簡単です:call manage.py loaddata <fixturename>、 どこ <fixturename>は、作成したフィクスチャファイルの名前です。

2
Marcelo Fonseca

私はこのライブラリを使用しています

https://pypi.org/project/Django-seed/

from Django_seed import Seed

seeder = Seed.seeder()

from myapp.models import Game, Player
seeder.add_entity(Game, 5)
seeder.add_entity(Player, 10)

inserted_pks = seeder.execute()
1

データ移行を作成できます。.. https://docs.djangoproject.com/en/2.0/topics/migrations/#data-migrations

python manage.py makemigrations --empty appname
1
0of1