JSON 文件的结构如下:
"quarterstaff": {
"id": 10,
"img": "quarterstaff_lg.png",
"dname": "Quarterstaff",
"components": null,
"created": false
},
"oblivion_staff": {
"id": 67,
"img": "oblivion_staff_lg.png",
"dname": "Oblivion Staff",
"components": [
"quarterstaff",
"sobi_mask",
"robe"
],
"created": true
},
我在导入组件值时遇到问题。"组件"值是配方中用于创建新项目的其他项目的键名称。这些是我的模型:
class Item(models.Model):
unique_id = models.IntegerField(unique=True)
itemkey = models.CharField(max_length=255)
dname = models.CharField(max_length=255)
img = models.CharField(max_length=255)
components = models.ManyToManyField('self', blank=True, symmetrical=False, through='Composition')
class Composition(models.Model):
whole = models.ForeignKey(Item, related_name = 'as_a_whole')
component = models.ForeignKey(Item, related_name = 'as_a_part')
我使用命令文件从 JSON 文件导入数据。
def update_item(self, key, item):
try:
db_item = Item.objects.get(unique_id=item['id'])
print 'Updating %s..' % item['dname']
except Item.DoesNotExist:
print 'Creating %s..' % item['dname']
db_item = Item()
db_item.unique_id = item['id']
db_item.itemkey = key
db_item.dname = item['dname']
db_item.img = item['img']
db_item.components = item['components']
db_item.save()
def fetch_items(self, result):
try:
for key, item in result['itemdata'].items():
self.update_item(key, item)
我收到此错误:AttributeError: Cannot set values on a ManyToManyField which specifies an intermediary model. Use items.Composition's Manager instead.
我相信这是因为db_item.save()
,因为我在 ManyToManyField 上使用直通选项,您显然不能使用添加、创建或分配来创建关系。
那么我应该怎么做才能将组件值放入数据库呢?如果这个问题太宽泛,我深表歉意?我真的不知道我在做什么!我对编程完全陌生,Python是我的第一门语言。
另外,当我查看数据库中的 items.item 架构时,没有"组件"表。为什么?ManyToManyFields是放在单独的表中还是其他什么?
添加到您使用的多对多项目
components.add(item)
即
for component in items["components"]:
db_item.components.add(component)
多对多关系使用所谓的查找表,您已通过 through="Composition"
参数定义了此类表。这意味着复合模型将用作存储这些关系的特殊表。
如果你不指定一个直通表,Django 将自动创建一个透明使用。