在最近的一个项目中,使用到了pymonogo,然后对数据库数据进行crud
但是在查询过程中遇到了这个问题:
File "/home/mahdi/.local/lib/python3.7/site-packages/fastapi/encoders.py", line 143, in jsonable_encoder
raise ValueError(errors)
ValueError: [TypeError("'ObjectId' object is not iterable"), TypeError('vars() argument must have __dict__ attribute')]
查询语句为全查:
pcs = db.monitor_traffic_pc.find({})
for p in pcs:
data["pcs"].append(p)
尝试换了很多种写法也无济于事,这个问题的根源在于每次往数据库插数据的时候,数据库会自动生成一个_id字段,该字段的数据类型为ObjectId:
然后在每次查询的时候查出来的每条数据都是带有这个_id的,这个字段因为类型特殊,无法进行遍历等操作,所以解决方法就是将这个字段的类型做转换:
# fix ObjectId & FastApi conflict
import pydantic
from bson.objectid import ObjectId
pydantic.json.ENCODERS_BY_TYPE[ObjectId]=str
此方法对于我来说是有效的
如果还想深入研究可以查看https://github.com/tiangolo/fastapi/issues/1515