0

我正在创建一个记录玩家统计数据的模型。
通过首先手动输入数据点,我可以让 Django 使用自然键将数据序列化到一个 json 文件中,使用dumpdata --natural. 我的计划是复制这种序列化格式以大量插入其他数据点;问题是 Django 不会使用loaddata. 抛出的错误是

DeserializationError: int() 参数必须是字符串或数字,而不是“列表”

我已经稍微简化了抱怨的 json 数据,但它看起来像这样:
{"pk": 1, "model": "nba.metric", "fields": {"player": ["Kobe Bryant", ["Lakers", 2012]]}}

我的模型是这样的:

class TeamManager(models.Manager):
    def get_by_natural_key(self, name, season):
        return self.get(name=name, season=season)
class Team(models.Model):
    name = models.CharField(max_length=20)
    season = models.IntegerField()
    class Meta:
        unique_together = ('name', 'season')
    objects = TeamManager()
    def natural_key(self):
        return (self.name, self.season)

class PlayerManager(models.Manager):
    def get_by_natural_key(self, name, team):
        return self.get(name=name, team=team)
class Player(models.Model):
    name = models.CharField(max_length=100)
    team = models.ForeignKey(Team)
    class Meta:
        unique_together = ('name', 'team')
    objects = PlayerManager()
    def natural_key(self):
        return (self.name, self.team.natural_key())

class Metric(models.Model):
    player = models.ForeignKey(Player)
    # ...

非常感谢任何输入,谢谢!

4

1 回答 1

2

我有完全相同的(棘手的)问题并设法以这种方式解决它。您需要更改get_by_natural_key方法,以便它接受team.natural_key()您在内部使用的 2 隐含给出的参数Player.natural_key()。尝试这个:

class PlayerManager(models.Manager):
    def get_by_natural_key(self, name, team_name, team_season):
        return self.get(name=name, team__name=team_name, team__season=team_season)

如果您找到了 Django 自动处理此问题的另一个解决方案,我会很高兴听到它。

于 2013-08-01T10:16:24.343 回答