Maison >développement back-end >Tutoriel Python >Comment sérialiser des objets SQLAlchemy en JSON ?

Comment sérialiser des objets SQLAlchemy en JSON ?

Barbara Streisand
Barbara Streisandoriginal
2024-12-02 04:01:15743parcourir

How to Serialize SQLAlchemy Objects to JSON?

Sérialisation SQLAlchemy-to-JSON : un guide

Dans le domaine de la gestion des données, la sérialisation des données aux formats JSON ou XML est un élément crucial tâche de partage et de consommation de données de manière transparente sur différentes applications et plates-formes. Bien que Django offre des fonctionnalités de sérialisation intégrées pratiques pour les modèles ORM, vous vous demandez peut-être comment y parvenir avec SQLAlchemy.

Le dilemme de la sérialisation des objets SQLAlchemy

Dans votre quête pour sérialiser les résultats des requêtes SQLAlchemy en JSON ou XML, vous avez peut-être rencontré des défis, tels que la réception d'une TypeError lors de l'utilisation json.dumps() en raison de la nature inhérente des objets SQLAlchemy ORM qui ne sont pas sérialisables en JSON. Cela soulève la question de savoir s'il existe une complexité inhérente à l'exécution de cette tâche apparemment courante.

Une solution simple : dictionnaires d'objets personnalisés

Bien qu'il n'y ait pas de valeur par défaut sérialiseur facilement disponible dans SQLAlchemy, une solution simple consiste à créer une fonction personnalisée pour convertir vos objets SQLAlchemy ORM en dictionnaires, qui peuvent ensuite être facilement sérialisés en JSON.

Considérez l'exemple suivant :

class User:
    def as_dict(self):
        # Iterate over the table columns and create a dictionary with column names as keys and column values as values
        return {c.name: getattr(self, c.name) for c in self.__table__.columns}

En utilisant la méthode as_dict(), vous pouvez facilement sérialiser vos objets SQLAlchemy :

user = User()
json_data = json.dumps(user.as_dict())

Ressources supplémentaires

Pour plus d'informations sur la conversion des objets de ligne SQLAlchemy en dictionnaires Python, reportez-vous à l'article complet "Comment convertir un objet ligne SQLAlchemy en un dict Python ?"

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn