ValueError: TypeError(“‘numpy.float32‘ object is not iterable“

在最近的一个项目中,使用到了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

猜你喜欢

转载自blog.csdn.net/weixin_45717984/article/details/126952928
今日推荐