python-Pymongo UUID搜索不返回肯定存在的文档

尝试在python中定义一个可以搜索给定UUID的函数,如下所示:

def getid(in_id):
    return list(CollectionVar.find({"_id":UUID(in_id)}))

并传递一个UUID.我可以像这样从Studio 3T中获取一个我知道存在的UUID:

db.getCollection("CollectionName").find({"_id":UUID("5002aa11-eeb7-4e68-a121-dd51497d2572")})

以上查询恰好返回一个文档. python查询中的同一UUID绝对不返回任何内容.我可以很容易地在其他(非UUID)字段上找到文档,例如,以下代码在较早版本的同一文档上可以正常工作:

def getname(fn,sn):
    return list(CollectionVar.find({"Firstname":re.compile(fn, re.IGNORECASE), "Surname":re.compile(sn, re.IGNORECASE)}))

这似乎是uuid.UUID类的问题,而不是pymongo问题?谁能看到这个问题?

PyMongo版本3.6.1

解决方法:

我已经解决了对于遇到此问题的其他人,解决方案如下:

from bson.binary import Binary, UUID_SUBTYPE

def getcust(inid):
    newuuid=uuid.UUID(inid).bytes
    return list(DealershipConsumer.find({"_id": Binary(bytes(bytearray(newuuid)), UUID_SUBTYPE)}))

UUID_SUBTYPE需要设置为您使用的UUID的任何子类型-在我的情况下是4.

上一篇:python pymongo操作之增删改查


下一篇:如何使用pymongo将日期时间字符串作为ISODate插入Mongodb