私はDjangoで開発してきましたが、Djangoのデータベースにデータをシードする方法があるかどうか疑問に思っていました。
Ruby on Railsでは、seed.rbを使用し、コマンドラインで「rake db:seed」を実行します。
主な理由は、プロジェクトの初期化のためにステータス、タイプなどに関するデータをシードすることです。
似たようなものはありますか?
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
)。
お役に立てれば。乾杯!
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>
は、作成したフィクスチャファイルの名前です。
私はこのライブラリを使用しています
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()
データ移行を作成できます。.. https://docs.djangoproject.com/en/2.0/topics/migrations/#data-migrations
python manage.py makemigrations --empty appname