[英]Many to many save django
我正在创建一个新闻应用程序,其中文章和作者之间存在多对多关系。 我目前拥有的模型如下所示:
class Author(models.Model):
name = models.CharField(max_length=100, null=True)
class Article(models.Model):
authors = models.ManyToManyField(Author)
article_title = models.CharField(max_length=250, unique_for_date="pub_date", null=True)
pub_date = models.DateTimeField(null=True)
我的数据结构如下所示:
{'contributors': [{'author': 'Author One'}, {'author': 'Author Two'}],
'publication_date': '2016-01-20T19:58:20Z',
'title': 'Article title'}
我试图插入保留文章和作者之间关系的数据,但无法弄清楚如何一次性插入多个作者。 我目前拥有的代码看起来像这样,但抛出AttributeError: 'tuple' object has no attribute 'authors'
错误:
contributor = data['contributors']
publication_date = data['publication_date']
title = data['title']
a = Article.objects.get_or_create(
article_title=title,
pub_date=publication_date,
)
for c in contributor:
author = c['author']
au = Author.objects.get_or_create(name=author)
a.authors.add(au)
任何建议,帮助,指导深表感谢。 让我知道是否需要澄清。 哦,我正在使用python3.5和Django1.9。 干杯
UPDATE
我通过将代码更改为以下方式来完成此工作:
a = Article.objects.get_or_create(
article_title=title,
pub_date=publication_date,
)
for c in contributor:
article = Article.objects.get(article_title=title)
author = Author.objects.create(name=c['author'])
article.authors.add(author)
但是,我想在author
上使用use get_or_create
,但这会导致错误: TypeError: int() argument must be a string, a bytes-like object or a number, not 'Author'
。 有什么想法吗?
最后更新
通过更改解决:
author = Author.objects.create(name=c['author'])
至:
author, created = Author.objects.get_or_create(name=c['author'])
如@mipadi建议
get_or_create
返回一个2元组(对象,已创建),第二个元素是一个布尔值,指示是否创建了对象。 所以a
是元组。 您应该执行以下操作:
a, created = Article.objects.get_or_create(...)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.