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

Modules Perl Discussion :

Problème module spreadsheet "can't call method Worksheet"


Sujet :

Modules Perl

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 45
    Points : 36
    Points
    36
    Par défaut Problème module spreadsheet "can't call method Worksheet"
    Bonjour,
    Suite à un passage d'un serveur en local sous Windows à un serveur distant sous Linux, j'ai du reprendre certains scripts perl d'import qui utilisaient win32....
    Donc, depuis hier, je me bats un peu avec le module Spreadsheet:arseExcel et j'obtiens toujours la meme erreur à savoir :
    "Can't call method "Worksheet" on a undefined value" sur le ligne suivante

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    my $exWorksheet = $exBook->Worksheet(1);
    A priori, d'après ce que j'ai compris en cherchant un peu partout, j'ai un problème de définition du workbook, seulement, je ne vois pas du tout où est le problème...
    Mon fichier test.xls se trouve dans le répertoire qui contient aussi mon script perl.

    Voici un bout de mon script :
    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
     
     
    use Spreadsheet::ParseExcel;
    use strict;
    use DBI;
     
    my $oExcel = new Spreadsheet::ParseExcel;
    my $exBook = $oExcel->Parse("test.xls");
    my $exWorksheet = $exBook->Worksheet(1);
    $line=2;
    $col = 1;
    while($exWorksheet->Cell($line,'A')->{'Value'}){
          $var = $exWorksheet->Cell($line,$col)->{'Value'};
          $cel = $exWorksheet->Cell('1',$col)->{'Value'};
    .......
    }
    Merci d'avance pour toute aide et bonne journée quand meme....
    Virginie

  2. #2
    Expert éminent
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Points : 8 586
    Points
    8 586
    Par défaut
    Citation Envoyé par boniface
    Mon fichier test.xls se trouve dans le répertoire qui contient aussi mon script perl.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    my $exBook = $oExcel->Parse("test.xls");
    my $exWorksheet = $exBook->Worksheet(1);
    Es-tu sûr d'être dans le bon répertoire quand tu lances ton script ? Le répertoire courant dans ton script n'est pas forcément celui où se trouve ton script, mais plutôt celui à partir duquel on l'a lancé.

    Rajoute un test d'existence :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    die "test.xls n'est pas là !" if( not -e "test.xls" );
    --
    Jedaï

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 45
    Points : 36
    Points
    36
    Par défaut
    Je viens de tester ton idée, mais il semblerait que ça ne soit pas ça, le fichier est bien présent...

  4. #4
    Expert éminent
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Points : 8 586
    Points
    8 586
    Par défaut
    Dans ce cas, vérifie si $exBook est bien undef après le Parse() :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    my $exBook = $oExcel->Parse("test.xls") || die "Parse() a échoué !\n";
    Si c'est le cas et que test.xls existe bien, ça signifie que test.xls est soit corrompu, soit incompatible avec le module (pour une raison quelconque : version du format trop récente/ancienne ?).

    --
    Jedaï

  5. #5
    Membre actif
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    172
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 172
    Points : 208
    Points
    208
    Par défaut
    Salut,
    Citation Envoyé par boniface
    Voici un bout de mon script :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
     
    my $oExcel = new Spreadsheet::ParseExcel;
    my $exBook = $oExcel->Parse("test.xls");
    my $exWorksheet = $exBook->Worksheet(1);
    Essai
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    my $oExcel = new Spreadsheet::ParseExcel::Workbook;
    my $exBook = $oExcel->Parse("test.xls");
    my $exWorksheet = $exBook->Worksheet(1);
    --
    lami20j

  6. #6
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 45
    Points : 36
    Points
    36
    Par défaut
    Citation Envoyé par lami20j
    Salut,
    Essai
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    my $oExcel = new Spreadsheet::ParseExcel::Workbook;
    my $exBook = $oExcel->Parse("test.xls");
    my $exWorksheet = $exBook->Worksheet(1);
    Je viens de tester ta solution, et j'obtiens une autre erreur que j'avais au tout début à savoir :
    Can't call method "Worksheet" on unblessed reference at import_excel.pl line 984.

    Pfff, je n'y comprend rien, ya personne qui a une petite idée???

    Merci d'avance....

  7. #7
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 45
    Points : 36
    Points
    36
    Par défaut
    Citation Envoyé par Jedai
    Dans ce cas, vérifie si $exBook est bien undef après le Parse() :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    my $exBook = $oExcel->Parse("test.xls") || die "Parse() a échoué !\n";
    Si c'est le cas et que test.xls existe bien, ça signifie que test.xls est soit corrompu, soit incompatible avec le module (pour une raison quelconque : version du format trop récente/ancienne ?).

    --
    Jedaï
    Ton idée était la bonne, il semblerait que le Parse() echoue...
    Je vais essayer de tester avec d'autres fichiers xls....
    Si quelqu'un a une autre suggestion ou des tests auquels je ne pense pas forcément, chui tjs preneuse!!
    Merci à tous les 2 en tt cas!

  8. #8
    Membre actif
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    172
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 172
    Points : 208
    Points
    208
    Par défaut
    Regarde sur cpan Spreadsheet ParseExcel
    --
    lami20j

  9. #9
    Expert éminent
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Points : 8 586
    Points
    8 586
    Par défaut
    Citation Envoyé par boniface
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    use Spreadsheet::ParseExcel;
    use strict;
    use DBI;
     
    my $oExcel = new Spreadsheet::ParseExcel;
    my $exBook = $oExcel->Parse("test.xls");
    D'après la doc ce que tu utilises est une vieille interface, avant toute chose essaie avec la nouvelle interface :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    use Spreadsheet::ParseExcel;
    use strict;
    use DBI;
     
    my $exBook = Spreadsheet::ParseExcel::Workbook->Parse("test.xls");
    --
    Jedaï

Discussions similaires

  1. Erreur du type : Can't call method
    Par david59390 dans le forum Langage
    Réponses: 5
    Dernier message: 06/01/2009, 13h39
  2. Error : can't call method "fetchrow_array"
    Par juzii dans le forum SGBD
    Réponses: 16
    Dernier message: 22/07/2008, 18h03
  3. Can't call method "mail" on an undefined value
    Par pausg dans le forum Modules
    Réponses: 5
    Dernier message: 18/07/2008, 17h14
  4. Réponses: 1
    Dernier message: 17/01/2007, 17h10
  5. Can't call method "mail" on an undefined value
    Par hpalpha dans le forum Modules
    Réponses: 2
    Dernier message: 18/01/2006, 10h50

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