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

JavaScript Discussion :

lecture fichier JSON


Sujet :

JavaScript

  1. #1
    Membre à l'essai
    Inscrit en
    Mai 2009
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 18
    Points : 10
    Points
    10
    Par défaut lecture fichier JSON
    bonjour, j'aimerai savoir s'il était possible de lire un fichier JSON dans une page PHP pour ensuite introduire ces données dans la base de données.
    mes données sont au format suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    {
     
    data : [
     
    ["010-0","MA","Jerry","Keith",50,57,80,46,"2008-10-02"],
    ["010-1","SP","Charles","Marks",79,37,40,90,"2008-04-24"]
    	],
     
    pageInfo : {totalRowNum:30	},
     
    exception:''
     
    }

  2. #2
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Salut,
    Oui, c'est possible, utilise la fonction json_decode de php.

  3. #3
    Membre à l'essai
    Inscrit en
    Mai 2009
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 18
    Points : 10
    Points
    10
    Par défaut
    merci pour ta réponse andry.aime
    Je viens d'essayer la fonction json_decode mais comment fait on pour accéder au valeur de champ.

  4. #4
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Points : 4 835
    Points
    4 835
    Par défaut
    munos46 commence par lire la documentation officielle :
    http://us.php.net/json_decode

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <?php
     
    $json = '{"foo-bar": 12345}';
     
    $obj = json_decode($json);
    print $obj->{'foo-bar'}; // 12345
     
    ?>

  5. #5
    Membre à l'essai
    Inscrit en
    Mai 2009
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 18
    Points : 10
    Points
    10
    Par défaut
    j'ai déjà vue cette documentation, mon problème est que le résultat retourné par json_decode m'affiche NULL .

  6. #6
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Points : 4 835
    Points
    4 835
    Par défaut
    dans ce cas la , le problème viens d'ailleurs
    comme quoi quand on s'exprime correctement

    Montre nous ton fichier json , et ton morceau de code pour le lire

  7. #7
    Membre à l'essai
    Inscrit en
    Mai 2009
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 18
    Points : 10
    Points
    10
    Par défaut
    code pur la lecture
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <?php
        // Instruction 1  
        $fp = fopen ("./data/masterData.js", "r");  
        // Instruction 2  
        $contenu_du_fichier = fread ($fp, filesize('./data/masterData.js'));  
        // Instruction 3  
        fclose ($fp);  
        // Instruction 4  
            $json = json_decode ($contenu_du_fichier);
       print $json-> {'compte'} ;
    ?>
    contenue du fichier masterData.js
    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
    {
     
    data : [
     
    ["compe":"010-0","MA","Jerry","Keith",50,57,80,46,"2008-10-02"],
    ["compe":"010-1","SP","Charles","Marks",79,37,40,90,"2008-04-24"],
    ["compe":"010-2","SP","Vincent","Harrison",91,75,31,40,"2008-02-17"],
    ["compe":"020-3","RA","Edward","Sidney",61,31,80,47,"2008-10-16"],
     
    	],
     
    pageInfo : {totalRowNum:30	},
     
    exception:''
     
    }

  8. #8
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Points : 4 835
    Points
    4 835
    Par défaut
    es tu certains que tu as bien récupéré le contenu de ton fichier ??

    essayes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $obj = json_decode(file_get_contents($url));
    ( url vaut le path complet de ton fichier )

  9. #9
    Membre à l'essai
    Inscrit en
    Mai 2009
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 18
    Points : 10
    Points
    10
    Par défaut
    pour ce qui est du retour oui cela m'affiche bien les données du fichiers, c'est le traitement qui ne fonctionne pas.

    maintenant j'ai une erreur sur cette ligne :
    print $json-> {'compte'} ;

    erreur retournée
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Notice: Trying to get property of non-object in C:\Program Files\EasyPHP 3.0\www\adrien\saisie des ecritures V0.2\maquette\lectureJSON.php on line 10

  10. #10
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Points : 4 835
    Points
    4 835
    Par défaut
    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
    {
     
    "data" : [
     
    ["compe":"010-0","MA","Jerry","Keith",50,57,80,46,"2008-10-02"],
    ["compe":"010-1","SP","Charles","Marks",79,37,40,90,"2008-04-24"],
    ["compe":"010-2","SP","Vincent","Harrison",91,75,31,40,"2008-02-17"],
    ["compe":"020-3","RA","Edward","Sidney",61,31,80,47,"2008-10-16"],
     
    	],
     
    "pageInfo" : {totalRowNum:30	},
     
    "exception":''
     
    }
    et comme ça ?

  11. #11
    Membre à l'essai
    Inscrit en
    Mai 2009
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 18
    Points : 10
    Points
    10
    Par défaut
    toujours pas j'ai même essayer en mettant juste les données mais rien à faire il m'accepte pas le tableau

  12. #12
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Salut,
    ton JSON est mal formé.
    Utilises des accolades à la place des crochets ;
    Il y a une virgule en trop à la fin de l'objet data.

    Ensuite, tu tentes de récupérer des propriétés "compte" alors que dans ton objet, ce sont des propriétés "compe" ;
    Tu fais un print sur une collection de valeurs.

  13. #13
    Membre à l'essai
    Inscrit en
    Mai 2009
    Messages
    18
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 18
    Points : 10
    Points
    10
    Par défaut
    merci bovino, cela fait beaucoup d'erreur pour que cela fonctionne.
    J'ai cependant corrigé ces erreurs et j'ai toujours le même message.

  14. #14
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2012
    Messages
    59
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2012
    Messages : 59
    Points : 55
    Points
    55
    Par défaut
    Bonjour,

    J'ai exactement le même besoin mais pour une action java.

    Existe-t-il une fonction équivalente pour java?

  15. #15
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonjour,

    Tu as plusieurs librairies que tu peux utiliser: jSONArray, JSONObjet, Google-gson, ...
    Fait une recherche sur eux sur google.

    A+.

  16. #16
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2012
    Messages
    59
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2012
    Messages : 59
    Points : 55
    Points
    55
    Par défaut
    Merci beaucoup, j'ai finalement utiliser la librairie gson de google

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

Discussions similaires

  1. [Python 2.X] Lecture fichier Json en clair
    Par Thierry_V dans le forum Général Python
    Réponses: 11
    Dernier message: 11/09/2014, 20h36
  2. lecture de fichier Json
    Par Clarkocb dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 11/09/2008, 16h53
  3. [AJAX] Lecture d'un fichier json par ajax
    Par zizoo510 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 18/08/2008, 12h11
  4. [AJAX] lecture fichier json distant
    Par 4R416N33 dans le forum Général JavaScript
    Réponses: 0
    Dernier message: 08/06/2008, 20h01

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