从 mongoengine 以 json 格式返回列表字段引用字段

问题描述

我的小测试很有趣 api 几乎可以工作,尽管有一件事我并没有完全将列表字段确定为 json...有时我无法将对象作为 json 返回。

如果我将一些模型定义为:

class RegularDocument(db.Document):
    doc_name = db.StringField()
    doc_type = db.StringField()
    def to_json(self):
        return {"_id": str(self.pk),"doc_name":self.doc_name,"doc_type":self.doc_type }

class FancyDocument(db.Document):
    name = db.StringField()
    reg_docs = db.ListField(db.ReferenceField(RegularDocument))
    def to_json(self):
        return { "_id": str(self.pk),"name":self.name,"regular_docs": self.reg_docs} 

然后是我的测试代码

api.py

@app.route('/getfancydocument/<id>',methods=['GET'])
def app_getfancydocument(id):
    fd = FancyDocument.objects().get_or_404(id=id)
    return json.jsonify(fd.to_json()),200

test_api.py

def test_getfancydocument():
    url = 'http://localhost:5000/getfancydocument/607e4f06e111b81c0ec2f09f'
    headers = {'Content-Type': 'application/json'}
    resp  =requests.get(url,headers=headers)
    print(resp.json())

无法返回列表数据...它说RegularDocument不是可序列化的...这是有道理的,它不喜欢我在该字段上的to_json。那么如何让这些数据打印出来或返回呢?

我的 api.py 中有另一个方法可以返回所有项目,并且工作正常:

@app.route('/getfancydocuments')
def get_fancydocuments():
    fd= FancyDocument.objects()
    return json.jsonify(fd.to_json()),200

在 test_api.py 中:

def test_getFancyDocuments():
    url = 'http://localhost:5000/getfancydocuments'
    headers = {'Content-Type': 'application/json'}
    resp  =requests.get(url,headers=headers)
    print(resp.json)
    print(resp.text) # this makes it pretty print just fine?

返回json中的项目列表就好了,甚至是fancydocuments上的reg_docs数组。所以不确定单数发生了什么?顺便说一句......我通过这个将项目添加到我的 FancyDocument 中:

api.py

#this feels messy as can be but learning mongodb still....
@app.route('/fancydocumentaddregular/<id>',methods=['PUT'])
def addregdocstofancydoc(id):
    body = request.get_json()    
    the_list = []
    for value in body["reg_docs"]:        
        print(value)
        theid = value["id"]
        print(theid)
        the_list.append(RegularDocument.objects.get_or_404(id=theid))
    
    fd = FancyDocument.objects.get_or_404(id=id)
    fd.name = body['name']
    fd.reg_docs = the_list    
    fd.save()
    return json.jsonify(fd.to_json()),201

test_api.py

def test_addRegDocumentsToFancyDocument():
    url = 'http://localhost:5000/fancydocumentaddregular/607e376a4f7cc6debbce207a'
    headers = {'Content-Type': 'application/json'}
    payload = {'name': 'Fancy new dpc','reg_docs': [{'id':'607df9b0384ebbd7b54b299f'},{'id':'607dfa620a9263843104e74e'},{'id':'607dfb82341af037de9466e6'}]}  
    resp = requests.put(url,headers=headers,data=json.dumps(payload,indent=4))

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...