質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.34%

Djangoで初期データを投入したい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 1,021

score 18

前提・実現したいこと

ポケモン図鑑のようなものを作っています。
後々Django rest frameworksでAPIを作成する予定です。
その際、初期データを

python manage.py loaddata post_initial.json


で投入したいと考えておりますが、どう改善すればよいかわからず難儀しております。
「local variable 'pk' referenced before assignment」などとありますが、どこを修正すればよいかわかりかねております。

発生している問題・エラーメッセージ

Traceback (most recent call last):
  File "C:\Users\[USERNAME]\AppData\Local\Programs\Python\Python38\lib\site-packages\django\core\serializers\base.py", line 287, in deserialize_m2m_values
    for pk in field_value:
TypeError: 'int' object is not iterable

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "C:\Users\[USERNAME]\AppData\Local\Programs\Python\Python38\lib\site-packages\django\core\serializers\json.py", line 69, in Deserializer
    yield from PythonDeserializer(objects, **options)
  File "C:\Users\[USERNAME]\AppData\Local\Programs\Python\Python38\lib\site-packages\django\core\serializers\python.py", line 122, in Deserializer
    values = base.deserialize_m2m_values(field, field_value, using, handle_forward_references)
  File "C:\Users\[USERNAME]\AppData\Local\Programs\Python\Python38\lib\site-packages\django\core\serializers\base.py", line 294, in deserialize_m2m_values
    raise M2MDeserializationError(e, pk)
UnboundLocalError: local variable 'pk' referenced before assignment

The above exception was the direct cause of the following exception:

Traceback (most recent call last):
  File "manage.py", line 21, in <module>
    main()
  File "manage.py", line 17, in main
    execute_from_command_line(sys.argv)
  File "C:\Users\[USERNAME]\AppData\Local\Programs\Python\Python38\lib\site-packages\django\core\management\__init__.py", line 401, in execute_from_command_line
    utility.execute()
  File "C:\Users\[USERNAME]\AppData\Local\Programs\Python\Python38\lib\site-packages\django\core\management\__init__.py", line 395, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "C:\Users\[USERNAME]\AppData\Local\Programs\Python\Python38\lib\site-packages\django\core\management\base.py", line 328, in run_from_argv
    self.execute(*args, **cmd_options)
  File "C:\Users\[USERNAME]\AppData\Local\Programs\Python\Python38\lib\site-packages\django\core\management\base.py", line 369, in execute
    output = self.handle(*args, **options)
  File "C:\Users\[USERNAME]\AppData\Local\Programs\Python\Python38\lib\site-packages\django\core\management\commands\loaddata.py", line 72, in handle
    self.loaddata(fixture_labels)
  File "C:\Users\[USERNAME]\AppData\Local\Programs\Python\Python38\lib\site-packages\django\core\management\commands\loaddata.py", line 114, in loaddata
    self.load_label(fixture_label)
  File "C:\Users\[USERNAME]\AppData\Local\Programs\Python\Python38\lib\site-packages\django\core\management\commands\loaddata.py", line 172, in load_label
    for obj in objects:
  File "C:\Users\[USERNAME]\AppData\Local\Programs\Python\Python38\lib\site-packages\django\core\serializers\json.py", line 73, in Deserializer
    raise DeserializationError() from exc
django.core.serializers.base.DeserializationError: Problem installing fixture 'C:\Users\[USERNAME]\Documents\[*****]\django_rest_framework_test\Pokedex\fixtures\post_initial.json':

該当のソースコード

model.py

from django.db import models

class Pokemon(models.Model):
    name= models.CharField(max_length=32,primary_key = True)
    type= models.ManyToManyField(
    "Type",
    )

class Type(models.Model):
    id = models.AutoField(primary_key = True)
    name=models.CharField(max_length=32)

post_initial.json

[
  {
    "model": "Pokedex.Pokemon",
    "pk": 1,
    "fields": {
      "name": "ヒトカゲ",
      "type":1
    }
  },
  {
    "model": "Pokedex.Pokemon",
    "pk": 2,
    "fields": {
      "name": "フシギダネ",
      "type":2
    }
  },
  {
    "model": "Pokedex.Pokemon",
    "pk": 3,
    "fields": {
      "name": "ゼニガメ",
      "type":3
    }
  },
  {
    "model": "Pokedex.Pokemon",
    "pk": 4,
    "fields": {
      "name": "リザードン",
      "type":[1,5]
    }
  },
  {
    "model": "Pokedex.Pokemon",
    "pk": 5,
    "fields": {
      "name": "フシギバナ",
      "type":[1,4]
    }
  },
  {
    "model": "Pokedex.Pokemon",
    "pk": 6,
    "fields": {
      "name": "カメックス",
      "type":3
    }
  },
  {
    "model": "Pokedex.Type",
    "pk": 1,
    "fields": {
      "name": "ほのお"
    }
  },
  {
    "model": "Pokedex.Type",
    "pk": 2,
    "fields": {
      "name": "くさ"
    }
  },
  {
    "model": "Pokedex.Type",
    "pk": 3,
    "fields": {
      "name": "みず"
    }
  },
  {
    "model": "Pokedex.Type",
    "pk": 4,
    "fields": {
      "name": "どく"
    }
  },
  {
    "model": "Pokedex.Type",
    "pk": 5,
    "fields": {
      "name": "ひこう"
    }
  }
]

どうぞよろしくお願いいたします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+2

テスト的にモデルを登録後、dumpdataコマンドで出力される結果と比較して、確認した方が良いと思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/05/14 16:19 編集

    ご回答ありがとうございます。
    adminから手動でデータを登録し、datadumpでうまくいきました。

    こちらのページを参考にさせていただきました。
    https://narito.ninja/blog/detail/103/

    もしよろしければ、次の質問にも回答いただけるとありがたく思います。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.34%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る