 Schema Handling with Marshmallow
Schema Handling with Marshmallow
For better organization and maintainability, it's beneficial to create a separate file for working with schemas, typically named schemas.py. This file will house all the schema classes required for our API, enabling us to structure and validate data efficiently.
The Basics of Marshmallow Schemas:
Here's how we import and define our schemas with Marshmallow:
from marshmallow import Schema, fields
class TeamSchema(Schema):
    id = fields.Int(dump_only=True)
    title = fields.Str(required=True)
    league = fields.Str(required=True)
    club_id = fields.Int(required=True, load_only=True)
The Schema class from Marshmallow is used to create schema definitions, with various fields types specifying the data types and validation requirements for our API's data models.
Nested Schemas and Avoiding Recursion:
One common challenge in using schemas is avoiding infinite recursion. For instance, when we serialize a team, it includes a list of players, and each player might reference back to their team, creating a loop.
To circumvent this issue, we can introduce 'plain' or simplified schemas, which only include the necessary fields when nested within other schemas.
Implementation of Plain Schemas:
We create plain versions of our schemas to include only the essential fields:
class PlainTeamSchema(Schema):
    title = fields.Str(required=True, unique=True)
    club = fields.Nested(PlainClubSchema(), dump_only=True)
class PlainClubSchema(Schema):
    name = fields.Str(required=True)
These plain schemas are then used within the original schemas to break the potential infinite loop caused by nested relationships.
Refactoring Our Schemas:
After defining our plain schemas, we refactor our main schemas to inherit from them:
class TeamSchema(PlainTeamSchema):
    id = fields.Int(dump_only=True)
    title = fields.Str(required=True)
    league = fields.Str(required=True)
    club_id = fields.Int(required=True, load_only=True)
    club = fields.Nested(PlainClubSchema(), dump_only=True)
    managers = fields.List(fields.Nested(PlainUserSchema()), dump_only=True)
    players = fields.List(fields.Nested(PlainPlayerSchema()), dump_only=True)
class PlayerSchema(PlainPlayerSchema):
    id = fields.Int(dump_only=True)
    first_name = fields.Str(required=True)
    last_name = fields.Str(required=True)
    position = fields.Str(required=True)
    number = fields.Int(required=True)
    team_id = fields.Int(load_only=True)
    team = fields.Nested(PlainTeamSchema(), dump_only=True)
In these refactored schemas, we ensure that nested relationships use the plain schemas, preventing recursive serialization issues.
Testing Our Schemas:
With our schemas refactored, it's crucial to test them to ensure they work as intended. We can serialize sample data to JSON and deserialize JSON payloads to Python objects, checking for any errors or issues.
We've made significant progress in creating and refining our Marshmallow schemas. In the next part of the course, we will integrate these schemas with additional endpoints and functionalities, putting them into practice within our API.
Note
Full code from the video can be checked in GitHub by the link.
1. What is a Schema in Marshmallow?
2. Can Marshmallow schemas be nested?
Merci pour vos commentaires !
Demandez à l'IA
Demandez à l'IA
Posez n'importe quelle question ou essayez l'une des questions suggérées pour commencer notre discussion
Posez-moi des questions sur ce sujet
Résumer ce chapitre
Afficher des exemples du monde réel
Awesome!
Completion rate improved to 3.03 Schema Handling with Marshmallow
Schema Handling with Marshmallow
Glissez pour afficher le menu
For better organization and maintainability, it's beneficial to create a separate file for working with schemas, typically named schemas.py. This file will house all the schema classes required for our API, enabling us to structure and validate data efficiently.
The Basics of Marshmallow Schemas:
Here's how we import and define our schemas with Marshmallow:
from marshmallow import Schema, fields
class TeamSchema(Schema):
    id = fields.Int(dump_only=True)
    title = fields.Str(required=True)
    league = fields.Str(required=True)
    club_id = fields.Int(required=True, load_only=True)
The Schema class from Marshmallow is used to create schema definitions, with various fields types specifying the data types and validation requirements for our API's data models.
Nested Schemas and Avoiding Recursion:
One common challenge in using schemas is avoiding infinite recursion. For instance, when we serialize a team, it includes a list of players, and each player might reference back to their team, creating a loop.
To circumvent this issue, we can introduce 'plain' or simplified schemas, which only include the necessary fields when nested within other schemas.
Implementation of Plain Schemas:
We create plain versions of our schemas to include only the essential fields:
class PlainTeamSchema(Schema):
    title = fields.Str(required=True, unique=True)
    club = fields.Nested(PlainClubSchema(), dump_only=True)
class PlainClubSchema(Schema):
    name = fields.Str(required=True)
These plain schemas are then used within the original schemas to break the potential infinite loop caused by nested relationships.
Refactoring Our Schemas:
After defining our plain schemas, we refactor our main schemas to inherit from them:
class TeamSchema(PlainTeamSchema):
    id = fields.Int(dump_only=True)
    title = fields.Str(required=True)
    league = fields.Str(required=True)
    club_id = fields.Int(required=True, load_only=True)
    club = fields.Nested(PlainClubSchema(), dump_only=True)
    managers = fields.List(fields.Nested(PlainUserSchema()), dump_only=True)
    players = fields.List(fields.Nested(PlainPlayerSchema()), dump_only=True)
class PlayerSchema(PlainPlayerSchema):
    id = fields.Int(dump_only=True)
    first_name = fields.Str(required=True)
    last_name = fields.Str(required=True)
    position = fields.Str(required=True)
    number = fields.Int(required=True)
    team_id = fields.Int(load_only=True)
    team = fields.Nested(PlainTeamSchema(), dump_only=True)
In these refactored schemas, we ensure that nested relationships use the plain schemas, preventing recursive serialization issues.
Testing Our Schemas:
With our schemas refactored, it's crucial to test them to ensure they work as intended. We can serialize sample data to JSON and deserialize JSON payloads to Python objects, checking for any errors or issues.
We've made significant progress in creating and refining our Marshmallow schemas. In the next part of the course, we will integrate these schemas with additional endpoints and functionalities, putting them into practice within our API.
Note
Full code from the video can be checked in GitHub by the link.
1. What is a Schema in Marshmallow?
2. Can Marshmallow schemas be nested?
Merci pour vos commentaires !