在db.ListField(BaseList)中查找对象

时间:2014-10-12 17:50:34

标签: python mongodb flask mongoengine flask-mongoengine

我有一个模型如下:

class Primary(db.Document):
    primaryName = db.StringField(required=True, max_length=20)
    secondaries = db.ListField(db.EmbeddedDocumentField(Secondary))

class Secondary(db.EmbeddedDocument):
    secondaryName = db.StringField(required=True, max_length=20)
    secondarySurname = db.StringField(max_length=20)

我希望获得具有特定名称的 Secondary 对象,或者如果它不存在则创建它。到目前为止,我还没有找到比这更好的方法:

# get the object if it exists already. Create otherwise
targetSecondary = None
for curSecondary in primary.secondaries:
    if curSecondary.secondaryName == 'targetName':
        targetSecondary = curSecondary
        break
if not targetSecondary:
    targetSecondary = Secondary(secondaryName='targetName')
    primary.secondaries.append(targetSecondary)
targetSecondary.secondarySurname = 'blahblah'

我想知道是否有更好的方法(我几乎可以肯定),如果它只是来自MongoEngine的一些现成方法,我还不知道。提前感谢您的帮助。

1 个答案:

答案 0 :(得分:0)

不确定您的问题,但您可以使用类似isinstance函数的内容来检查它是否是某个类的实例。

您可以使用isinstance()检查某个名称是否是您所需类别的实例

>>> class A:
...     pass
... 
>>> a = None
>>> b = A()
>>> isinstance(a,A)
False
>>> isinstance(b,A)
True
>>> 

如果你得到False我想你可以创建实例。