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 Perl Discussion :

lire un fichier excel avec Perl


Sujet :

Langage Perl

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2012
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2012
    Messages : 10
    Par défaut lire un fichier excel avec Perl
    Bonjour à tous,

    Je suis un débutant en Perl et je souhaite lire un fichier excel par ligne et par colonne pour retrouver une valeur.

    J'ai écrit le code suivant:

    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
    sub lireTableauExel{
    # ------------------------Declaration des variables locales---------------
    	my $valeur;			# valeur dans la case du tableau exel
    	my $col;			# Colone dans le tableau excel
    	my $entete;		# entete du fichier excel
    	my $row;			# ligne
    	my $excel;			# Objet permettant de traiter des fichier excel
    	my $sheet; 		# feuille exel
    	my $message;
    		#------------------------------------------------------------------
     
    	#ouvre le fichier excel du serveur et parcourt la liste des packages
     
    $recensementAppareil = "$repertoire\\recensementAppareil.xls";
    $sheet=$excel->{Worksheet}[0]; #selection la 1ere feuille 			
    	if(!$sheet){
    		ecritLog("impossible de lire le fichier $recensementAppareil.xls");
    	}else{	
    		foreach $row ($sheet->{MinRow}+1 .. $sheet->{MaxRow}) { #on saute la 1ere ligne
    			foreach $col ($sheet->{MinCol} ..  $sheet->{MaxCol}){
    				$entete=$sheet->{Cells}[0][$col]->{Val};  
    					$valeur=$sheet->{Cells}[$row][$col]->{Val};
    					$message=$message." $entete:  $valeur,     "	
    			}#foreach
    				ecritLog("$message"); 
    		}#foreach
    	}
    }

    Je vérifie la syntaxe de mon script avec MS DOS, celle ci est ok. Mais quand je la lance j'ai un problème au niveau de la fonction if(!$sheet), à chaque fois il m'affiche le message "Impossible de lire le fichier... " Je n'arrive pas à rentrer dans la fonction else, et je ne sais pas pourquoi..

    Je vous serai très reconnaissant si vous pouviez m'aider
    en vous remerciant

  2. #2
    Rédacteur/Modérateur

    Avatar de Lolo78
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mai 2012
    Messages
    3 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 612
    Billets dans le blog
    1
    Par défaut
    Tu n'as pas ouvert le fichier excel. Le programme ne peut donc trouver la feuille.

  3. #3
    Membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2012
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2012
    Messages : 10
    Par défaut
    Si justement, je l'ai lancé avec le fichier excel ouvert après je l'ai testé en le laissant mais rien à faire..

  4. #4
    Membre du Club
    Homme Profil pro
    Inscrit en
    Juin 2012
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2012
    Messages : 10
    Par défaut
    Est ce que le fait qu'il y ait des cases fusionnées dans mon fichier excel empeche le script de le lire correctement? (désolé si c'est une question bête)

  5. #5
    Rédacteur/Modérateur

    Avatar de Lolo78
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Mai 2012
    Messages
    3 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 612
    Billets dans le blog
    1
    Par défaut
    Tu dois ouvrir ton fichier Excel dans ton programme, avec la commande du module Excel permettrant d'ouvrir le classeur (je ne l'ai pas fait depuis 2007 ou 2008, mais ça doit être open).

  6. #6
    Membre émérite Avatar de Gardyen
    Homme Profil pro
    Bio informaticien
    Inscrit en
    Août 2005
    Messages
    637
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Bio informaticien

    Informations forums :
    Inscription : Août 2005
    Messages : 637
    Par défaut
    de plus excel bloque tout autre accès au fichier une fois qu'il l'a ouvert, il te faut fermer excel avant de lancer ton script

Discussions similaires

  1. Ouvrir et lire un fichier excel avec un script powershell
    Par Shikamaru86 dans le forum Scripts/Batch
    Réponses: 2
    Dernier message: 19/03/2013, 13h28
  2. Lire et ecrire un fichier excel avec perl
    Par Bengeldim dans le forum Langage
    Réponses: 3
    Dernier message: 22/07/2008, 17h23
  3. [Excel] Comment lire des fichiers excel avec php?
    Par dear_rihab dans le forum Bibliothèques et frameworks
    Réponses: 5
    Dernier message: 02/11/2007, 12h38
  4. Lire un fichier EXCEL avec PHP
    Par lenstoi dans le forum Langage
    Réponses: 2
    Dernier message: 03/09/2007, 12h38
  5. Peut-on lire un fichier Excel avec MATLAB ?
    Par nico_ippo dans le forum MATLAB
    Réponses: 1
    Dernier message: 05/11/2006, 18h37

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