我有两个彼此相关的物体。我希望能够通过浏览相关属性来访问另一个对象。
E.g。 A.b_relationship.obj.some_property
如何在不创建循环导入的情况下执行此操作?
# lib.py
class Relationship(object):
def __init__(self, obj):
self.obj = obj
# a.py
class A(object):
b_relationship = Relationship(B)
# b.py
class B(object):
a_relationship = Relationship(A)
为清楚起见,我已经添加了这个额外的例子。显然,SQLAlchemy使用backref
属性解决了这个问题。我不确定在没有破坏它的工作方式的情况下将这种东西应用到棉花糖中是多么可行。也许我需要改变自己的心态?
from marshmallow import Schema
from marshmallow.fields import String
from project.database import db
class PersonModel(db.Model):
name = db.Column(db.String)
class PetModel(db.Model):
name = db.Column(db.String)
owner = db.relationship('PersonModel', backref='pets')
class PersonSchema(Schema):
name = fields.String(init_arg='some value')
pets = fields.Relationship(related_schema=PetSchema)
class PetSchema(Schema):
name = fields.String()
owner = fields.Relationship(related_schema=PersonSchema)
答案 0 :(得分:6)
从这里: http://marshmallow.readthedocs.org/en/latest/nesting.html#two-way-nesting
查看字符串如何用于该类; AuthorSchema指的是BookSchema':
class AuthorSchema(Schema):
# Make sure to use the 'only' or 'exclude' params
# to avoid infinite recursion
books = fields.Nested('BookSchema', many=True, exclude=('author', ))
class Meta:
fields = ('id', 'name', 'books')
class BookSchema(Schema):
author = fields.Nested(AuthorSchema, only=('id', 'name'))
class Meta:
fields = ('id', 'title', 'author')
我认为在你的情况下,你想用many=False
做同样的事情。我从来没有使用过棉花糖,但在Django,它很相似,我们使用的类路径就像" my_app.MyClass"而不是MyClass
以避免循环导入。
答案 1 :(得分:1)
您可以实现RelationshipManager
(也称为注册表),所有可以成为关系一部分的类必须注册。
Relationship
初始化程序可以接受与其相关的类的名称,而不是实际的类对象。
最后,关系类本身可以从初始化时(通过管理器)给出的名称延迟加载与其相关的真实类。