IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Python Discussion :

Flask et Json file


Sujet :

Python

  1. #1
    Membre confirmé
    Femme Profil pro
    étudiant master
    Inscrit en
    Février 2014
    Messages
    167
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : étudiant master

    Informations forums :
    Inscription : Février 2014
    Messages : 167
    Par défaut Flask et Json file
    Salut,

    Je travaille avec Flask dans développement Web, coté back-end.
    Le but est de faire des requetes sur postgresql et d'enregistrer le résultat dans un fichier .json

    app.py

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    import os
    from flask import Flask, request, jsonify
    from flask_sqlalchemy import SQLAlchemy
    import json
     
     
    app = Flask(__name__)
     
    app.config.from_object("config.DevelopmentConfig")
    app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
    db = SQLAlchemy(app)   #to handle the database transactions.
     
    from models import Build
     
     
    @app.route("/")
    def hello():
        return "Hello World!"
     
    @app.route("/getall")
    def get_all():
        try:
            datas = Build.query.all()
     
            return jsonify([e.to_dict() for e in datas])
     
        except Exception as e:
            return(str(e))
    models.py

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    class Build(db.Model, SerializerMixin):
     
        serialize_types = (
            (WKBElement, lambda x: to_shape(x).to_wkt()),
            #(AnyOtherType, serialize)
        )
        __tablename__ = 'batiment1'
     
        id_batiment = db.Column(db.Integer, primary_key=True)
        z = db.Column(db.Integer)
        geom = db.Column(Geometry(geometry_type='POLYGON', srid=4326))
        classe= db.Column(db.String())
     
     
        def __init__(self, z, geom, classe):
            self.z = z
            self.geom = geom
            self.classe=classe
     
        def __repr__(self):
            return '<id_batiment {}>'.format(self.id_batiment)
    quand j'exécute localhost/getall, cela fonctionne et il m'affiche le résultat sous format json.

    Question:
    comment je peux exporter ou enregistrer ce resultat dans un fichier .json ??

  2. #2
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 716
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 716
    Par défaut
    Salut,

    Citation Envoyé par noramokh Voir le message
    comment je peux exporter ou enregistrer ce resultat dans un fichier .json ??
    En utilisant la bibliothèque JSON.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 828
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 828
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par noramokh Voir le message
    comment je peux exporter ou enregistrer ce resultat dans un fichier .json ??
    Tu peux utiliser les possibilités d'export de l'OS. Si t'es sous Linux et que ton programme se nomme "toto.py", alors au lieu d'appeler python3 toto.py ce qui te met le résultat à l'écran, tu appelles python3 toto.py >result.json.
    Windows offre aussi une possibilité analogue.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  4. #4
    Membre confirmé
    Femme Profil pro
    étudiant master
    Inscrit en
    Février 2014
    Messages
    167
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : étudiant master

    Informations forums :
    Inscription : Février 2014
    Messages : 167
    Par défaut
    la solution:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    res=json.dumps([e.to_dict() for e in datas])
     
     
            with open('requete.json', 'w') as outfile:
                json.dump(res, outfile)

    merci à tous

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Python 3.X] Flask JSON postgres enregistrement
    Par nathieb dans le forum Réseau/Web
    Réponses: 2
    Dernier message: 19/11/2016, 21h58
  2. Fullcalendar avec JSON file
    Par amalliap dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 15/04/2016, 17h50
  3. [Python 3.X] json file to list or dict
    Par Seylione dans le forum Général Python
    Réponses: 3
    Dernier message: 12/02/2016, 10h19

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo