我是 Django 的新手。我正在尝试使用 Django 保存 json 数据。我使用 MongoDB 作为后端和一对多关系方法来存储数据 - http://docs.mongodb.org/manual/tutorial/model-embedded-one-to-many-relationships-between-documents/
这是我的模型:
class OtherInfo(models.Model):
info_1 = models.CharField(max_length=200)
info_2 = models.CharField(max_length=200)
info_3 = models.CharField(max_length=200)
def __unicode__(self):
return u'%s %s %s' % (self.info_1, self.info_2, self.info_3)
class ModelInfo(models.Model):
name = models.CharField(max_length=200)
email = models.CharField(max_length=200)
other_info = ListField(EmbeddedModelField(OtherInfo))
def __unicode__(self):
return u'%s %s' % (self.name, self.email)
问题是 -
@api_view(['GET', 'PUT', 'POST'])
def save(request, format=None):
serializer = mySerializer(data=request.DATA)
if serializer.is_valid():
serializer.save()
return Response(status=status.HTTP_201_CREATED)
return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)
序列化器 -
class other_info_serializer(serializers.ModelSerializer):
class Meta:
model = OtherInfo
fields = ('info_1', 'info_2', 'info_3')
class mySerializer(serializers.ModelSerializer):
other_info=other_info_serializer(many=True)
class Meta:
model = ModelInfo
fields = ('name', 'email','other_info')
我希望将上述信息保存在数据库中,如下所示
{
_id: "joe",
name: "Joe Bookreader",
email: "email@example.com",
other_info: [
{
info_1 : "123 Fake Street",
info_2: "Faketon",
},
{
info_1: "1 Some Other Street",
info_2: "Boston",
}
]
}
现在当我在 URL 中发送帖子数据时
http://127.0.0.1:8080/save/
Parameter 1 : "name":"sample name"
Parameter 2 : "email":"sample@email.com"
Parameter 3 : [{'info_1':'Google','info_2':'Save'},{'info_1':'Hackhathon','info_2':'Present'}]
在执行上述请求时,我得到 -
{"other_info": [{"non_field_errors": ["Expected a list of items."]}]}
对发生的错误有什么建议吗?
编辑
也尝试传递名称值对。但仍然是同样的问题。
Parameter 3 : "other_info" : [{'info_1':'Google','info_2':'Save'},{'info_1':'Hackhathon','info_2':'Present'}]
最佳答案
此问题是由 RelationsList 引起的 - 它没有自己的 save 函数,但父序列化程序调用了它。
github issue 上存在完全相同的问题. 他们说处理嵌套对象仍处于繁重的开发阶段。 ( Link )
但我做了a patch for this (如下所示),您可以通过 sample project 进行测试.
class RelationsList(list):
_deleted = []
def save(self, **kwargs):
[obj.save(**kwargs) for obj in self]
关于django - [ {"non_field_errors": ["Expected a list of items."]}] when saving data in Django Rest with MongoDB,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24866507/
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我正在使用这个:4.times{|i|assert_not_equal("content#{i+2}".constantize,object.first_content)}我之前声明过局部变量content1content2content3content4content5我得到的错误NameError:wrongconstantnamecontent2这个错误是什么意思?我很确定我想要content2=\ 最佳答案 你必须用一个大字母来调用ruby常量:Content2而不是content2。Aconstantnamestart
我在MiniTest::Spec和Capybara中使用以下规范:find_field('Email').must_have_css('[autofocus]')检查名为“电子邮件”的字段是否具有autofocus属性。doc说如下:has_css?(path,options={})ChecksifagivenCSSselectorisonthepageorcurrentnode.据我了解,字段“Email”是一个节点,因此调用must_have_css绝对有效!我做错了什么? 最佳答案 通过JonasNicklas得到了答案:No
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
我想设置一个默认日期,例如实际日期,我该如何设置?还有如何在组合框中设置默认值顺便问一下,date_field_tag和date_field之间有什么区别? 最佳答案 试试这个:将默认日期作为第二个参数传递。youcorrectlysetthedefaultvalueofcomboboxasshowninyourquestion. 关于ruby-on-rails-date_field_tag,如何设置默认日期?[rails上的ruby],我们在StackOverflow上找到一个类似的问
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我正在尝试从Postgresql表(table1)中获取数据,该表由另一个相关表(property)的字段(table2)过滤。在纯SQL中,我会这样编写查询:SELECT*FROMtable1JOINtable2USING(table2_id)WHEREtable2.propertyLIKE'query%'这工作正常:scope:my_scope,->(query){includes(:table2).where("table2.property":query)}但我真正需要的是使用LIKE运算符进行过滤,而不是严格相等。然而,这是行不通的:scope:my_scope,->(que
我正在尝试编写一个将文件上传到AWS并公开该文件的Ruby脚本。我做了以下事情:s3=Aws::S3::Resource.new(credentials:Aws::Credentials.new(KEY,SECRET),region:'us-west-2')obj=s3.bucket('stg-db').object('key')obj.upload_file(filename)这似乎工作正常,除了该文件不是公开可用的,而且我无法获得它的公共(public)URL。但是当我登录到S3时,我可以正常查看我的文件。为了使其公开可用,我将最后一行更改为obj.upload_file(file
我克隆了一个rails仓库,我现在正尝试捆绑安装背景:OSXElCapitanruby2.2.3p173(2015-08-18修订版51636)[x86_64-darwin15]rails-v在您的Gemfile中列出的或native可用的任何gem源中找不到gem'pg(>=0)ruby'。运行bundleinstall以安装缺少的gem。bundleinstallFetchinggemmetadatafromhttps://rubygems.org/............Fetchingversionmetadatafromhttps://rubygems.org/...Fe