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

Langage PHP Discussion :

Json : mon update se fait sur une autre ligne de mon tableau


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Inscrit en
    Novembre 2009
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 5
    Par défaut Json : mon update se fait sur une autre ligne de mon tableau
    Bonjour à tous,
    Je suis débutant et je ne code que en php , pas de jquery java ou autre pour le moment .

    Je vous explique mon projet :

    je suis occupé de faire une bibliothèque multimédia, dans ce projet il y a deux parti :

    1 - les catégories : Action, Drame, western ect .. ( ça, c'est bon, creation, modification, pas de soucis pour les catégories )

    2 - les films que je classe suivant les catégories,

    exemple :

    Action - Aventures

    1 - Cross the Line
    2 - Wrong Turn
    3 - Rams
    jusque là tout vas bien, je peux modifier une catégorie sans perdre mes films.

    là ou c'est étrange c'est que lorsque je sélectionne un film à modifier (avec get + 2 variables) j'obtiens bien la catégorie le film séléctionné dans le formulaire et quand je modifie le formulaire ( faute ou autres infos ), la modification se fais sur l'id du film qui suits, exemple si je modifie le film n°2 c'est le n°3 qui prends les modifications.

    Voici le json que j'utilise :
    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
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
     
    [
        {
            "nom": "Action - Aventures",
            "id": 1,
            "films": [
                {
                    "id": 1,
                    "titre": "Cross the Line"
                },
                {
                    "id": 2,
                    "titre": "Wrong Turn"
                },
                {
                    "id": 3,
                    "titre": "Rams"
                }
            ]
        },
        {
            "nom": "Westerns",
            "id": 2,
            "films": [
                {
                    "id": 1,
                    "titre": "le bon , la brut et le truant"
                },
                {
                    "id": 2,
                    "titre": "Wrong Turn"
                },
                {
                    "id": 3,
                    "titre": "bouboulle"
                },
                {
                    "id": 4,
                    "titre": "les 7 nains"
                }
            ]
        },
        {
            "nom": "Drames",
            "id": 3,
            "films": [
                {
                    "id": 1,
                    "titre": "300"
                },
                {
                    "id": 2,
                    "titre": "La fin d'une époque"
                },
                {
                    "id": 3,
                    "titre": "le pianiste"
                },
                {
                    "id": 4,
                    "titre": "le lapin rose"
                }
            ]
        },
        {
            "nom": "Science-Fiction",
            "id": 4,
            "films": [
                {
                    "id": 1,
                    "titre": "Asteroid-a-Geddon"
                }
            ]
        }
    ]
    Voici le code entier du formulaire qui reçois les données du json:
    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
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
     
    <?php
    $films = json_decode(file_get_contents('../films.json'),true);
     
    if(isset($_GET['id1']) ){
        foreach($films as $film){
            if($film['nom'] == $_GET['id1']){
                $name = $film['nom'];
                $id = $film['id'];
     
            foreach ($film['films'] as $ep){
                if($ep['id'] == $_GET['id2']){
                    $titre = $ep['titre'];
                    $idfilm = $ep['id'];
                }
            }  
        }  
    }
    ?>
    <form method="post">
        <table cellpadding="2" cellspacing="2">
            <tr>
                <td>Nom</td>
                <td><input type="text" name="nom" value="<?php echo $name; ?>" disabled></td>
            </tr>
            <tr>
                <td>id</td>
                <td><input type="text" name="id" value="<?php echo $id; ?>" disabled></td>
            </tr>
            <tr>
                <td>Film</td>
                <td><input type="text" name="film" value="<?php echo $titre; ?>"></td>
            </tr>
            <tr>
                <td>idfilm</td>
                <td><input type="text" name="idfilm" value="<?php echo $idfilm; ?>" disabled></td>
            </tr>
            <tr>
                <td>&nbsp;</td>
                <td><input type="submit" value="Save" name="submitSave"></td>
                <td><a href="../index.php"> retour</a></td>
            </tr>
        </table>
    </form>
    <?php
    if(isset($_POST['film']))
    {
    foreach ($films as $key => $d) {
        if ($d['id'] == $id) {
            foreach ($d['films'] as $ep){
                if($ep['id'] == $idfilm){
                $films[$key]['films'][$ep['id']]['titre'] = $_POST['film'];
            break;
                }
            }
        break;
        }
    }
     
     
    $jsonfile = json_encode($films, JSON_PRETTY_PRINT);
    echo '<pre>';
    print_r($jsonfile);
    echo '<pre>';
    //$save = file_put_contents($films, $jsonfile);
    //header('location: ../index.php');
    }
    }
     
    ?>
    Alors je sais que mon code et basique pour certains, mais pour le moment j'apprends et je ne vois pas ou se trouve mon ou mes erreurs

    Merci par avance pour votre aide

    si vous avez besoin d'autres infos pas de soucis je vous les transmettrais

    Cordialement

    Mickael

  2. #2
    Nouveau membre du Club
    Inscrit en
    Novembre 2009
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 5
    Par défaut Résolu
    j'avais une petite erreur dans mon code
    pour ceux que cela intéresse :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    foreach ($d['films'] as $ep){
                if($ep['id'] == $idfilm){
                $films[$key]['films'][$ep['id']]['titre'] = $_POST['film'];
    il faut ajouter une variable ( ici $key2 ) et l'inclure dans l'a modification :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    foreach ($d['films'] as $key2 => $ep){
    			if($ep['id'] === $idfilm){
    			$data[$key]['films'][$key2]['titre'] = $_POST['film'];
    		break;
    de plus j'ai ajouté un connexion au fichier Json ( je ne sais pas pourquoi ?? car elle est déjà présente dans le haut de mon code !! )

    mais bon ça fonctionne maintenant.

    Merci à tous
    cordialement
    Mickael

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

Discussions similaires

  1. [AC-2003] Valeur d'une Zone de liste en fonction du choix fait sur une autre ZL
    Par Alexbreizhst dans le forum IHM
    Réponses: 4
    Dernier message: 23/02/2013, 07h08
  2. Réponses: 6
    Dernier message: 31/05/2010, 16h28
  3. Garder le résultat d'un tirage sur une autre ligne
    Par jacfld49 dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 01/02/2010, 17h47
  4. requête update en fonction d'une autre ligne
    Par Alien64 dans le forum Langage SQL
    Réponses: 6
    Dernier message: 16/07/2009, 12h42
  5. Réponses: 2
    Dernier message: 21/10/2007, 13h26

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