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 :

de .xls à .txt avec perl


Sujet :

Langage Perl

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    296
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 296
    Points : 73
    Points
    73
    Par défaut de .xls à .txt avec perl
    bonjour,
    j'ai déjà eu un script pour passer d'un .xls à un .txt.
    le script je l'ai testé et il marchait vraiment bien après une semaine, il ne marche plus et je ne sais pas de tout pourquoi.
    avec ce script je récupère les données de mon fichier .xls dans un fichier .txt
    mais la je n'ai rien dans le fichier.txt, il est vraiment vide 0ko

    voila le code
    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
    #!c:/perl/bin/perl
    use strict;
    use warnings;
    use Spreadsheet::ParseExcel;
    my @lignes;
     
    my $fichier_txt = "./xls_txt.txt";
    my $fichier_xls = "./cheklist_massy.xls";
    die "fichier non trouve !\n" if (! -s $fichier_xls);
    open(FIC, ">$fichier_txt" ) or die "impossible d'ecrire dans le fichier $fichier_txt : $!";
     
    my $oBook = Spreadsheet::ParseExcel::Workbook->Parse($fichier_xls);
    my($iR, $iC, $oWkS, $oWkC);
    foreach my $oWkS (@{$oBook->{Worksheet}}) {
        print "--------- SHEET:", $oWkS->{Name}, "\n";
        for(my $iR = $oWkS->{MinRow} ; defined $oWkS->{MaxRow} && $iR <= $oWkS->{MaxRow} ; $iR++) {  
          for(my $iC = $oWkS->{MinCol} ; defined $oWkS->{MaxCol} && $iC <= $oWkS->{MaxCol} ; $iC++) {  
            $oWkC = $oWkS->{Cells}[$iR][$iC];
            print FIC $oWkC->Value,"\t" if($oWkC); 
          }  
          print FIC "\n"; 
        }
    }
    close FIC;

  2. #2
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 498 771
    Points
    498 771
    Par défaut
    et quel est le message d'erreur?

  3. #3
    Membre chevronné
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2003
    Messages
    1 578
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2003
    Messages : 1 578
    Points : 2 022
    Points
    2 022
    Par défaut
    Et question subsidiaire : quand tu fais tes print sur les noms d'onglets de ton fichier Excel, ça apparait bien à l'affichage ?

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    296
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 296
    Points : 73
    Points
    73
    Par défaut
    je me rappel c'est vous djbril qui m'avez aidé sur ce script.
    je n'ai pas de tout de message d'erreur j'ai seulement la création du fichier résultat mais
    je ne comprend plus rien.
    merci de m'aider.

  5. #5
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 498 771
    Points
    498 771
    Par défaut
    peux tu nous donner ton fichier xls si ce n'est pas confidentiel?

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    296
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 296
    Points : 73
    Points
    73
    Par défaut
    le voila le fichier .xls.
    merci de votre aide.
    Fichiers attachés Fichiers attachés

  7. #7
    Membre chevronné
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2003
    Messages
    1 578
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2003
    Messages : 1 578
    Points : 2 022
    Points
    2 022
    Par défaut
    Citation Envoyé par mariafan Voir le message
    le script je l'ai testé et il marchait vraiment bien après une semaine, il ne marche plus et je ne sais pas de tout pourquoi.
    Petite question pas tout à fait aussi conne qu'elle en a l'air : es-tu sûr que tu exploites exactement le même script au caractère près ?

    A force de faire des essais, on renomme des scripts Perl, on les déplace, on les renomme à nouveau, on en teste un et hop, il marche. Sauf qu'on a oublié de le renommer avec son véritable nom de production, etc.

    On sait jamais, alors je pose la question

  8. #8
    Membre régulier
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    296
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 296
    Points : 73
    Points
    73
    Par défaut
    c'est une bonne piste.
    mes je les vérifier avant de poster ma question.
    MERCI BEAUCOUP POUR VOTRE AIDE
    je ne sais tjs pas pourquoi ça ne marche plus

  9. #9
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 498 771
    Points
    498 771
    Par défaut
    bah apres verif, je ne trouve pas ton soucis. Il ne fonctionne pas chez moi non plus. Le souci vient de ton fichier excel. Je ne sais pas d'ou vient le probleme ou si c'est un souci de version de ton excel avec le module perl. Bref le souci vient de ton fichier excel car quand je copie le contenu de ton fichier dans un nouveau fichier excel, j'ai plus de souci et j'ai bien un fichier txt plein.

    Exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    use Spreadsheet::ParseExcel;
     
    #objet excel
    my $fichier_excel = "cheklist_velizy2.xls";
    my $objet_excel = new Spreadsheet::ParseExcel;
    my $objet_fichier = $objet_excel->Parse($fichier_excel) or die "$!";
    => Bad file descriptor at G:\perl\art_perl\test2.pl

  10. #10
    Membre régulier
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    296
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 296
    Points : 73
    Points
    73
    Par défaut
    sincèrment je vois pas de tout .
    la seule différence entre les deux ie la semaine dernière et cette semaine et que cette semaine je récupère les .xls via le ftp automatiquement à l'aide d'un script perl. alors que l'autre fois je l'ai récupérer à l'aide de FileZilla

  11. #11
    Membre chevronné
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2003
    Messages
    1 578
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2003
    Messages : 1 578
    Points : 2 022
    Points
    2 022
    Par défaut
    Citation Envoyé par mariafan Voir le message
    sincèrment je vois pas de tout .
    la seule différence entre les deux ie la semaine dernière et cette semaine et que cette semaine je récupère les .xls via le ftp automatiquement à l'aide d'un script perl. alors que l'autre fois je l'ai récupérer à l'aide de FileZilla
    Autre question conne alors : les deux transferts FTP ont-ils transféré le fichier Excel en mode binaire ???

Discussions similaires

  1. modifier une ligne d'un fichier.txt avec perl
    Par amibar dans le forum Langage
    Réponses: 16
    Dernier message: 14/07/2012, 09h56
  2. update avec Perl
    Par mimilou dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 18/05/2004, 16h22
  3. Connexion avec Perl
    Par BARBIER dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 05/05/2004, 14h05
  4. faire des graphiques avec Perl
    Par And_the_problem_is dans le forum Modules
    Réponses: 2
    Dernier message: 16/07/2003, 16h08
  5. [reseaux] Comment creer un compte user à partir d'un formul avec perl
    Par oulai_evado dans le forum Programmation et administration système
    Réponses: 4
    Dernier message: 01/10/2002, 19h54

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