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

Django Python Discussion :

Exporter les données en json


Sujet :

Django Python

  1. #1
    Membre averti
    Profil pro
    Ingénieur en électronique
    Inscrit en
    Septembre 2004
    Messages
    419
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur en électronique

    Informations forums :
    Inscription : Septembre 2004
    Messages : 419
    Points : 333
    Points
    333
    Par défaut Exporter les données en json
    Bonjour ,

    Pour transmettre des données en json sur un site web , je fait ceci :

    fichier view.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
    	datasJson = {
    		"id_w": id_w,
    		"nom_w":w_name,
    .....................
    		'liste_w':liste_w,
     
     
     
     
    	}
     
    	dico_sortie = datas  
    	dico_sortie["datasJson"]=	datasJson
    	return render(request, 'avancement.html',dico_sortie)

    Et pour l'affichage ( dans template.html )

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <script>
      var datasJson = JSON.parse('{{ datasJson |safe }}');
      console.log(datasJson);
    </script>
    {%endif%}


    Pour les premières valeurs , pas de soucis . {'id_w': 289, 'nom_w': 'TEST_2018-09-20_05_A',

    Le soucis viens pour les listes j'ai pour exemple : liste_process_flow': <QuerySet ['DFB_Ba', 'FP_Unit', ...]>

    Peut t'on faire quelque chose pour supprimer <QuerrySet ? par exmple en indiquant au template que c'est safe Json

    Merci d'avance
    Matthieu

  2. #2
    Membre éclairé Avatar de grabriel
    Inscrit en
    Septembre 2006
    Messages
    946
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 946
    Points : 730
    Points
    730
    Par défaut
    Bonjour,

    Avec un mois de retard mais juste au cas ou si ça peux servir.

    pour un appel ajax ou avec un template, je comprends pas trop dans la question ce que tu veux faire.

    views.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
     
    def appel_ajax(request):
      """appel ajax depuis le template."""
      from django.http import JsonResponse
     
      data = {'key': 'value'}
      return JsonResponse(data)
     
    def appel_avec_template(request):
      """appel normal avec template."""
      import json
     
      contexte = {'datasJson': json.dumps({'key': 'value'})}
     
      return render(request, 'template.html', context)
    Si tu fait l'appel avec template tu peux directement accéder à tes données avec {{datasJson}} pas besoin de javascript.

    for looper avec un QuerySet utilise {% for %} {% endfor %}

Discussions similaires

  1. exporter les données entre deux tables différentes ?
    Par tizilfin dans le forum Oracle
    Réponses: 3
    Dernier message: 12/03/2007, 15h39
  2. Exporter les données d'une flexgrid vers Excel
    Par ecarbill dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 16/08/2006, 18h06
  3. [MySQL] Exporter les données d'une table en PHP
    Par caro_tpl dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 08/08/2006, 11h25
  4. exporter les données d'une DB dans un doc. pdf
    Par gagalive dans le forum API standards et tierces
    Réponses: 35
    Dernier message: 15/07/2006, 13h22
  5. Est-il possible d'exporter les données?
    Par frutix dans le forum Débuter
    Réponses: 8
    Dernier message: 21/06/2004, 10h27

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