Search code examples
pythonmarshmallow

cannot import schema from a model with one to many relationship


I have two models with one to many relationships:

from marshmallow import Schema, fields
from server import db, ma, app
from .category import CategorySchema


class Analysis(db.Model):
  __tablename__ = 'Analysis'
  __table_args__ = {'extend_existing': True}
  id = db.Column(db.Integer, primary_key=True)
  name = db.Column(db.String(120), index=True, unique=True)
  description = db.Column(db.Text, nullable=False)
  img = db.Column(db.LargeBinary, nullable=True)
  img_mimetype = db.Column(db.Text, nullable=True)
  img_name = db.Column(db.Text, nullable=True)
  category_id = db.Column(db.Integer, db.ForeignKey('Categories.id'), nullable=True)
  category = db.relationship("Category", back_populates="analysis")


class AnalysisSchema(ma.SQLAlchemyAutoSchema):
  class Meta:
    fields = ("id", "name", "description")
  category = fields.Nested(CategorySchema(exclude=['img', 'analysis']))
from marshmallow import Schema, fields

from server import db, ma, app
from sqlalchemy.ext.hybrid import hybrid_property
from .analysis import AnalysisSchema



class Category(db.Model):
    __tablename__ = 'Categories'
    __table_args__ = {'extend_existing': True}
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(120), index=True, unique=True)
    description = db.Column(db.Text, nullable=False)
    img = db.Column(db.LargeBinary, nullable=False)
    img_mimetype = db.Column(db.Text, nullable=False)
    img_name = db.Column(db.Text, nullable=False)
    analysis = db.relationship("Analysis", back_populates="category")

    @property
    def img_url(self):
        return "/categories/" + str(self.id)



class CategorySchema(ma.SQLAlchemyAutoSchema):
    class Meta:
        # model = Category
        fields = ("id", "name", "description", "img", "img_url", "analysis")
    analysis = fields.Nested(AnalysisSchema, many=True)


class CreateCategorySchema(Schema):
    name = fields.Str(required=True)
    description = fields.Str(required=True)


class UpdateCategorySchema(Schema):
    name = fields.Str(required=True)
    description = fields.Str(required=False)
    img = fields.Str(required=False)
    img_name = fields.Str(required=False)
    img_mimetype = fields.Str(required=False)

I don't understand why I'm getting this error: ImportError: cannot import name 'CategorySchema' from 'server.models.category' (/server/server/models/category.py)

The import on the Category model is working great while the one in the Analysis no.


Solution

  • You can avoid circular imports - the problem here - by passing the class name to nested as a string. For example:

    class AnalysisSchema(ma.SQLAlchemyAutoSchema):
      class Meta:
        fields = ("id", "name", "description")
      category = fields.Nested("CategorySchema", exclude=["img", "analysis"])