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

Bibliothèques et frameworks PHP Discussion :

[PHPExcel] Retrouver données d'une colonne


Sujet :

Bibliothèques et frameworks PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Homme Profil pro
    Apprenti en charge du SI
    Inscrit en
    Mars 2018
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Apprenti en charge du SI
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2018
    Messages : 3
    Par défaut [PHPExcel] Retrouver données d'une colonne
    Bonjour,

    J'utilise actuellement au travail la librairie PHPExcel et je bloque sur une chose qui me paraît pourtant assez simple..
    Je remplis un formulaire grâce à des données d'un fichier Excel, celà fonctionne très bien.
    exemple:
    Nom : exemple1.png
Affichages : 985
Taille : 1,6 Ko
    Voilà sur quoi je bloque:
    j'aimerais qu'avec cette données donc par exemple ici "Indoor", je parcours mon fichier excel appelé "MatriceFichier.xlsx" pour aller à la colonne nommée "Indoor" et ainsi récupérer les données dans cette colonne qui par exemple ici donne:
    Nom : indoorExemple.png
Affichages : 981
Taille : 6,9 Ko
    j'aimerais également récupérer les valeurs du flag (à droite) ce qui signifie 1 pour fichier obligatoire et 0 pour fichier facultatif.

    Pour l'exemple ci dessus j'ai utilisé Indoor, mais ça aurai pu être Outdoor, ou d'autre valeur. Cette valeur est récupérée de l'input de mon formulaire.
    Si vous avez des idées, merci.

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $l = 5; // la ligne
    while (($cell = $worksheet->getCellByColumnAndRow($c, $l)->getValue()) != '') {
    	if ($cell->getValue() == 'Indoor') {
    		echo 'trouvé à la colonne ' . $c;
                    break;
    	}
    	++$c;
    }
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Apprenti en charge du SI
    Inscrit en
    Mars 2018
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Apprenti en charge du SI
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2018
    Messages : 3
    Par défaut
    Tout d'abord merci pour ta réponse, j'essaie de l'intégrer à mon code existant.
    Le problème vient de la variable $c donc ici colonne. La variable n'est pas reconnue au moment getCellByColumnAndRow($c, $l)
    La valeur "Indoor" pourrait très bien être à la colonne 10 comme à la colonne 2. Sachant que Indoor n'est qu'une exemple que je vais remplacer ici par:
    if ($cell->getValue() == $typeBaie) {

    De plus quand je mets une valeur à $c comme par exemple 30 cela me donne une erreur à la ligne :
    if ($cell->getValue() == 'Indoor') {

    Fatal error: Uncaught Error: Call to a member function getValue() on string

  4. #4
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Il y a 2 appels à getValue : un dans l'affectation et un dans l'utilisation.
    Donc c'est soit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $l = 5; // la ligne
    while (($cell = $worksheet->getCellByColumnAndRow($c, $l)) != '') {
    	if ($cell->getValue() == 'Indoor') {
    		echo 'trouvé à la colonne ' . $c;
                    break;
    	}
    	++$c;
    }
    soit
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $l = 5; // la ligne
    while (($cell = $worksheet->getCellByColumnAndRow($c, $l)->getValue()) != '') {
    	if ($cell == 'Indoor') {
    		echo 'trouvé à la colonne ' . $c;
                    break;
    	}
    	++$c;
    }
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Apprenti en charge du SI
    Inscrit en
    Mars 2018
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Apprenti en charge du SI
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2018
    Messages : 3
    Par défaut
    Merci pour ton aide, j'ai réussi à faire fonctionner comme je le voulais.

  6. #6
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Le problème vient de la variable $c donc ici colonne. La variable n'est pas reconnue au moment getCellByColumnAndRow($c, $l)
    C'est justement le but de ce code, on parcours les colonnes jusqu'à trouver le bon $c.

    Par rapport à la correction de Celira, il manque aussi un petit
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $c = colonne_de_départ;
    au début
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

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

Discussions similaires

  1. Concaténer en ligne les données d'une colonne
    Par philben dans le forum Contribuez
    Réponses: 2
    Dernier message: 16/02/2015, 12h23
  2. transférer données d'une colonne A vers colonne B
    Par oliver75 dans le forum Excel
    Réponses: 2
    Dernier message: 19/06/2007, 17h24
  3. Réponses: 4
    Dernier message: 23/05/2007, 11h07
  4. Réponses: 3
    Dernier message: 26/07/2006, 14h58
  5. Effacer toutes les données d'une colonne
    Par denisfavre dans le forum Access
    Réponses: 5
    Dernier message: 12/10/2005, 15h20

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