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 :

[Tableaux] Extraction de valeur dans un tableau


Sujet :

Langage PHP

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 28
    Points : 18
    Points
    18
    Par défaut [Tableaux] Extraction de valeur dans un tableau
    Bonjour,

    J'ai le tableau suivant:

    $events_total[$date_tmp][] = array('rubrique' => '#ID_RUBRIQUE','link' => '#URL_ARTICLE', 'title' => '[(#TITRE|supprimer_numero|texte_scrip
    t)]', 'logo' => '<img src="../Logos/coeurv.png" alt=" "/>', 'desc' => '[(#DESCRIPTIF|supprimer_tags|attribut_html)]');
    et je n'arrive pas à en extraire les valeurs.
    Je voudrais trouver, par exemple, toutes les occurences de #ID_RUBRIQUE quand il vaut 135.

    J'essaye avec foreach, in_array, isset etc... mais rien n'y fait.
    Je ne comprends pas comment je dois traiter le [$date_tmp]

    Si quelqu'un peut m'aider... c'est bien volontier.

    Merci d'avance

    Pascal

  2. #2
    Expert éminent Avatar de Mr N.
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 5 418
    Points : 6 449
    Points
    6 449
    Par défaut
    Rien compris :o
    C'est qui qui vaut 135 ?

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 28
    Points : 18
    Points
    18
    Par défaut
    C'est #ID_RUBRIQUE qui vaut 135.

    Toutes les valeurs qui commencent par un # sont des variables de SPIP

    SI j'ai bien compris la structure du tableau $events_total, pour chaque valeur de $date_tmp j'ai un ensemble de valeurs (rubrique, link, title, logo, desc)

    Et je voudrais savoir, pour une date donnée de $date_tmp, combien j'ai d'occurence de la rubrique dont le ID vaut 135 (faut-il dire que c'est 'rubrique' qui vaut 135 ou bien que c'est #ID_RUBRIQUE qui vaut 135 ?).

    Pascal

  4. #4
    Expert éminent Avatar de Mr N.
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 5 418
    Points : 6 449
    Points
    6 449
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $nb = 0;
    foreach($events_total[$date_tmp] as $value) {
       if ($value['rubrique'] == 135) {
          $nb++;
       }
    }
    echo "il y a $nb rubrique qui valent 135";

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 28
    Points : 18
    Points
    18
    Par défaut
    Pfffff..... Merci bien !

    Par contre, il y a quelque chose que je ne comprends pas:

    Si je mets une date à laquelle ne correspond pas de rubrique, j'ai un message d'erreur:

    Warning: Invalid argument supplied for foreach() in /usr/local/www/inc-public.php3(60) : eval()'d code on line 746

    Parce que le but de l'opération c'est de tester ci pour une date quelconque, j'ai une entrée (dans le tableau) pour les rubriques.

    Pascal

  6. #6
    Expert éminent Avatar de Mr N.
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 5 418
    Points : 6 449
    Points
    6 449
    Par défaut
    Normal, la date n'existe pas ! Il faut tester...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $nb = 0;
    if (isset($events_total[$date_tmp])) {
       foreach($events_total[$date_tmp] as $value) {
          if ($value['rubrique'] == 135) {
             $nb++;
          }
       }
    }
    echo "il y a $nb rubrique qui valent 135";

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 28
    Points : 18
    Points
    18
    Par défaut
    Merci beaucoup ;-)

    J'y ai passé 3 heures sans rien obtenir :-(((

    C'est quand même chaud les tableaux !

    Pascal

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

Discussions similaires

  1. [Tableaux] Comparer des valeurs dans un tableau
    Par Dirty Harry dans le forum Langage
    Réponses: 13
    Dernier message: 03/02/2007, 00h52
  2. [Tableaux] retrouver une valeur dans un tableau
    Par tininou dans le forum Langage
    Réponses: 3
    Dernier message: 26/01/2007, 22h04
  3. Réponses: 6
    Dernier message: 26/12/2006, 17h01
  4. [Tableaux] Problème de valeur dans un tableau (array)
    Par Flushovsky dans le forum Langage
    Réponses: 15
    Dernier message: 24/03/2006, 13h56
  5. [Tableaux]Ajouter des valeurs dans un tableau
    Par Antoine1183 dans le forum Collection et Stream
    Réponses: 13
    Dernier message: 03/04/2005, 13h41

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