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 :

Insérer réponse JSON d'une requête HTTP dans une table MySQL


Sujet :

Python

  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2014
    Messages
    96
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2014
    Messages : 96
    Points : 51
    Points
    51
    Par défaut Insérer réponse JSON d'une requête HTTP dans une table MySQL
    Bonjour à tous,

    Je voudrai insérer dans une table MySQL la réponse en JSON d'une requête HTTP.

    Avant, je crée la table avec tous ces attributs (JSON keys)

    A l'heure actuelle j'insère une par une chaque valeur pour chaque JSON key. J'aimerai éviter cela et trouver une autre solution.


    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
     
        json_response = urllib.request.urlopen("http://xxx/file.json")
        data = json.load(json_response)
     
        headers = ""
        attr_allocate = ""
        headers_dict = dict(data["data"][0])
     
        for i in headers_dict:
           headers += '"' + I + '"' + ' VARCHAR(255),'
     
        headers = headers.strip(',')
     
        #Table creation
        create_request = "CREATE TABLE TAB (" + headers + ")"
        cursor.execute(create_request)
        con.commit()
     
        for i in data["data"]
           #Line where I specify all values...
           attr_allocate = '\'' + i["name"].replace("'","'\'") + '\'' + ...
           insert_request = "INSERT INTO TAB VALUES (" + attr_allocate + ");"
           cursor.execute(insert_request)
           con.commit()
           attr_allocate = ""

    Pouvez-vous m'aider?

    Merci à vous.

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    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 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Salut,

    Le problème se ramène à travailler sur clefs/valeurs d'un dict (qui est une structure de base Python).
    Premier soucis, l'ordre des clefs n'est pas garanti et peut varier d'une exécution à l'autre:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    >>> d = dict((k, i) for i, k in enumerate(list('abcd')))
    >>> d
    {'c': 2, 'd': 3, 'a': 0, 'b': 1}
    >>>
    car vous ne voudrez sans doute pas retrouver sous le champ "a" des valeurs du champ "c".
    Il faut donc définir l'ordre (des clefs) et le préserver :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    >>> z = []
    >>> for k in list('abcd'):
    ...     z.append( (k, d[k]))
    ...
    >>> z
    [('a', 0), ('b', 1), ('c', 2), ('d', 3)]
    >>>
    Puis séparer les clefs des valeurs en préservant cet ordre là:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    >>> list(zip(*z))
    [('a', 'b', 'c', 'd'), (0, 1, 2, 3)]
    >>>
    Enfin, avant d'écrire des requêtes comme:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
           insert_request = "INSERT INTO TAB VALUES (" + attr_allocate + ");"
           cursor.execute(insert_request)
    on lit la documentation qui explique qu'il ne faut surtout pas faire comme çà (et qui montre comment faire plus proprement).

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 12/12/2011, 10h07
  2. Réponses: 3
    Dernier message: 07/04/2011, 14h38
  3. Réponses: 6
    Dernier message: 31/05/2010, 14h12
  4. erreur dans une requête sql dans une fonction php
    Par frboyer dans le forum Langage
    Réponses: 3
    Dernier message: 07/04/2009, 13h37
  5. [Requête] Utilisation d'une fonction perso dans une requête
    Par Julien Dufour dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 16/03/2007, 09h53

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