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 :

creer un fichier json


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Septembre 2020
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2020
    Messages : 18
    Par défaut creer un fichier json
    Bonjour a toutes et à tous,

    Je me suis permis de crée un sujet afin que vous m'aidiez a répondre à cette problématique

    je dois a partir de données récupérer dans ma bd postgresql creer un fichier json

    voici mon code
    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
    if __name__ == '__main__':
     
        def bdToJson():
            import json
            from db_connect import db_connect
            sql = "SELECT  * FROM  information_schema.tables WHERE  table_schema='public' "
            connexion = db_connect()
            connexion.execute(sql)
            liste_table = connexion.fetchall()
            i = 0
            while i < len(liste_table):
                data = {
                    "base":
                        {
                            "nom": liste_table[i][2],
                            "export": "non"}
                }
     
                print(data)
                with open("bd.json", "w") as file:
                    json.dump(data, file)
                i = i + 1
     
    bdToJson()
    je veux donc un fichier json avec dedans la liste des table et "export non"
    or dans mon fichier json il n'y a que le dernier passage de la boucle qui écrase tout

    voici le resultat que je trouve dans mon fichier json
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    {"base": [{"nom": "tt", "export": "non"}]}
    pour ce qui est du print(data) la console me repond cela :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    {'base': [{'nom': 'test_table', 'export': 'non'}]}
    {'base': [{'nom': 'tt', 'export': 'non'}]}
    merci de bien vouloir me conseiller ou m'aiguillez afin que je trouve enfin réponse à ma question

  2. #2
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 741
    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 741
    Par défaut
    Salut,

    Citation Envoyé par benji1996 Voir le message
    merci de bien vouloir me conseiller ou m'aiguillez afin que je trouve enfin réponse à ma question
    Vous voulez peut être un fichier JSON qui contienne une entrée pour chaque élément de la table. Dans ce cas pourquoi réinitialiser data et écrire le fichier à chaque itération?

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

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Septembre 2020
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2020
    Messages : 18
    Par défaut
    Citation Envoyé par wiztricks Voir le message
    Salut,



    Vous voulez peut être un fichier JSON qui contienne une entrée pour chaque élément de la table. Dans ce cas pourquoi réinitialiser data et écrire le fichier à chaque itération?

    - W
    merci pour votre reponse mais jai resolu le problème a ajoutant cette ligne

    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
    if __name__ == '__main__':
     
        def bdToJson():
            import json
            from db_connect import db_connect
            sql = "SELECT  * FROM  information_schema.tables WHERE  table_schema='public' "
            connexion = db_connect()
            connexion.execute(sql)
            liste_table = connexion.fetchall()
            i = 0
            base_ex = []
            while i < len(liste_table):
                data = {
                    "base":
                        {
                            "nom": liste_table[i][2],
                            "export": "non"}
                }
     
                print(data)
                with open("bd.json", "w") as file:
                    json.dump(data, file)
                i = i + 1
     
    bdToJson()
    En tout cas merci pour votre aide

  4. #4
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 741
    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 741
    Par défaut
    Salut,

    Citation Envoyé par benji1996 Voir le message
    merci pour votre reponse mais jai resolu le problème a ajoutant cette ligne
    Il y a de çà mais il manque des bouts pour que le code que vous montrez fasse plus que le précédent...

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

  5. #5
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 833
    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 833
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par benji1996 Voir le message
    merci pour votre reponse mais jai resolu le problème a ajoutant cette ligne base_ex = []
    Personnellement je ne vois pas ce que cette variable (qui n'est même pas remplie ni même utilisée d'une quelconque façon par la suite) a pu résoudre.
    Tant que vous ouvrirez le fichier en mode "w" à chaque itération de la boucle, chaque itération écrasera le fichier précédent. Peut-être que ça "marchotte" ici parce que liste_table ne contient qu'un élément (donc la boucle ne fait qu'une itération) mais si ça change dans l'avenir...

    Citation Envoyé par benji1996 Voir le message
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    while i < len(liste_table):
    	data = {
    		"base": {
    			"nom": liste_table[i][2],
    			"export": "non",
    		}
    	}
     
    	print(data)
    	with open("bd.json", "w") as file: json.dump(data, file)
    	i = i + 1
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    for t in liste_table:
    	data = {
    		"base": {
    			"nom": t[2],
    			"export": "non",
    		}
    	}
     
    	print(data)
    	with open("bd.json", "w") as file: json.dump(data, file)
    Ce bout de code ne fait pas mieux que le précédent (lui aussi écrase le fichier à chaque itération) mais au-moins il suprime ce "i" totalement inutile en itérant directement sur la liste renvoyée par la requête.
    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]

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

Discussions similaires

  1. creer fichier Json à partir d'une DB Posrgresql
    Par trazomtg dans le forum Interfaçage autre langage
    Réponses: 1
    Dernier message: 02/03/2018, 13h46
  2. [Jar]comment creer un fichier JAR?
    Par ed_hunter dans le forum Eclipse Java
    Réponses: 1
    Dernier message: 24/05/2004, 11h44
  3. creer un fichier cpl
    Par Louis-Guillaume Morand dans le forum Windows
    Réponses: 5
    Dernier message: 04/03/2004, 19h10
  4. Réponses: 19
    Dernier message: 24/05/2002, 16h36
  5. [langage] comment créer des fichiers ?
    Par Anonymous dans le forum Langage
    Réponses: 3
    Dernier message: 05/05/2002, 16h33

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