Posez votre question Signaler

[PERL] lire contenu fichier .xls [Résolu]

ushiwa.sasuke - Dernière réponse le 16 juin 2008 à 11:51
bonjour,

voila je commence a apprendre le language PERL et j'aimerais savoir si il existe une commande ou un moyen de pourvoir lire le contenu d un fichier .xls et de le stocker dans une base de données ORACLE ???

Si oui quelles seraient les commandes...?

Merci d avance
Lire la suite 

[PERL] lire contenu fichier .xls »

25 réponses
Réponse
+1
moins plus
Bonjour,

Remarque:
#!C:\Perl\lib\perl.exe
Inutile sous MS-WINDOWS

Pour charger un fichier:

#!/usr/bin/perl -w
use strict;
# --- Retourne le contenu du fichier dont le chemin est passé en paramètre
sub lecture {
    my @contenu = ();
    open(FILE, "$_[0]") || die "Erreur E/S: $!\n";
    @contenu = <FILE>;
    close(FILE);
    return @contenu;
}


Pour utiliser les formats d'excel:
http://search.cpan.org/~kwitknr/DBD-Excel-0.06/Excel.pm

@+
kij_82 - 17 mai 2005 à 13:50
Je sus pas sur que sous windows,
#C:\Perl\bin\perl.exe
soit inutile, sans cela je ne peux pas le faire chez moi.
philtrain - 17 mai 2005 à 17:06
il faut lier les fichiers d'extension .pl et .pm avec l'exécutable perl

@+
kij_82kij_82 - 17 mai 2005 à 17:23
ah.. ok

Ajouter un commentaire
Réponse
+0
moins plus
Alors sasuke on ne sais pas ? Fais moi le malin hein quand ta pas ton chacras...

bon, plus sérieusement essaye un truc dans le style (moi aussi je débute en Perl alors c'est possible que ce soit pas tout à fait ca !) :
sub lecture {
    open IN, $_[0] or die "Impossible d'ouvrir le fichier $_[0] pour la cause suivante : $!\n";
    my $infos_fichier = "";
    while( $infos_fichier .= <IN> ) {
        ;
    }
    close IN;
    return $infos_fichier;
} 

Cette fonction s'appelle de la sorte : calcule("nomdufichier_avec_chemin");

Et puis apres tu fais une méthode qui ouvre une connexion à une base de donnée, tu crée ta requete et l'éxécute sur cette connexion, puis tu ferme la connexion.

Si tu ne sais pas faire les connexion, dit le et je pourrais t'aiguiller.

++
ushiwa.sasuke - 13 mai 2005 à 14:23
bon j ai tester plus ou moin le truc mais pour commencer avant de deja y sauver dans une base de données j ai essayé d y enregistrer dans un fichier .txt le truc c que il fait la les procedure mais il crée pas le fichier .txt donc je suis tjs dessus pour savoir pkoi...
kij_82 - 17 mai 2005 à 11:59
Oui en effet, j'ai tester ce que j'ai mis et il ne s'arrete pas
Faut juste mettre une condition d'arret.
kij_82 - 17 mai 2005 à 12:09
essaie ce script et utilise le à tes fin :
#!C:\Perl\lib\perl.exe

lecture("fich.txt");

sub lecture {
    open IN, $_[0] or die "Impossible d'ouvrir le fichier $_[0] pour la cause suivante : $!\n";
    my @infos_fichier;
    @infos_fichier = <IN>;
    my $i = 0;
    my $long = @infos_fichier;
    printf $long."\n";
    while( $i < $long ){
        print $infos_fichier[$i++]."\n";
    }
    
    close IN;
    return $infos_fichier;
} 



++
Ajouter un commentaire
Réponse
+0
moins plus
slt KIJ_82,
tu es sur que ton truc fonctionne (ça ne m'en a pas l'air)
Ajouter un commentaire
Réponse
+0
moins plus
merci bcp pour vos reponse cela dis j ai encore un petit truc preciser c est que je suis en linux et non en windows...
Ajouter un commentaire
Réponse
+0
moins plus
bonjour,

je suis en linux et non en windows...

C'est mieux pour le perl.

-> la première ligne du script:
#!/usr/bin/perl -w


Ensuite pour rendre le script exécutable:
chmod +x mon_script.pl

Pour exécuter le script:
./mon_script.pl

Bon amusement avec perl et linux.
Cordialement,

@+
Ajouter un commentaire
Réponse
+0
moins plus
dites moi, un de vous arriverai a me corriger car je vois vraiment pas l erreur que j ai faite...

#!/usr/bin/perl

sub lecture {
open (IN, "essai.xls") or die "Impossible d'ouvrir le fichier /home/hassler/Desktop/essai.xls pour la cause suivante : $!\n";
my $infos_fichier = "";
while( $infos_fichier .= <IN> ) {
;
}
close IN;
return $infos_fichier;
}
sub ecriture {
my $infos_fichier = $_[0];
open (OUT,">ecriturexls.txt");
print OUT $infos_fichier;
close(OUT);
}
$infos_fichier = &lecture;

&ecriture($infos_fichier);
Ajouter un commentaire
Réponse
+0
moins plus
Bonjour,

#!/usr/bin/perl -w
use strict;

sub lecture {
	my $fichier_in = "./essai.xls";
	open (IN, "$fichier_in") || die "Impossible d'ouvrir le fichier essai.xls pour la cause suivante : $!\n";
	my @infos_fichier = <IN>;
	close IN;
	return @infos_fichier;
}

sub ecriture {
	my $fichier_out = "./ecriturexls.txt";
	open (OUT,">$fichier_out");
	foreach my $valeur (@_) {
		print OUT $valeur;
	}
	close(OUT);
}

my @infos_fichier = &lecture;
&ecriture(@infos_fichier);


C'est ok commec ça?

@+
Ajouter un commentaire
Réponse
+0
moins plus
merci bcp philtrain, cela fonctionne !

cela dit encore une petite question...dans je lance le script et qu il ecrit dans le fichier : ecriturexls.txt, il se trouve qu il y a ca "ÐÏࡱ" a la place des valeur de mes cellules...pkoi ? est ce le contenu de mon fichier essaixls.pl qui est cripter ou pas ?
Ajouter un commentaire
Réponse
+0
moins plus
C'est du au format .xls.

Pour le travailler, il faut utiliser le bon module --> voir sur cpan
@+
Ajouter un commentaire
Réponse
+0
moins plus
alors je me suis renseigné et j ai un peu chercher dans le cpan et mais trouvé à aucun endroit ou il parlait du fichier xls....
kij_82 - 25 mai 2005 à 09:01
une bonne adresse pour toi :
http://ldp.ludost.net/linuxfocus/Francais/July2000/article156.meta.shtml

++
philtrain - 25 mai 2005 à 09:30
hello kij_82,

Attention, ushiwa a besoin de traiter des fichiers au format excel (xls) et non xsl

cordialement,

@+
kij_82 - 25 mai 2005 à 10:23
oups.. autant pour moi :)
Ajouter un commentaire
Réponse
+0
moins plus
Bonjour,

C'est ici:

http://search.cpan.org/dist/Spreadsheet-WriteExcel/

@+
Ajouter un commentaire
Réponse
+0
moins plus
je ne peux pas ouvrir 2 fichiers indiqués XLS je n'ai pas excel .
est-ce que ça a un rapport ? MERCI
Ajouter un commentaire
Réponse
+0
moins plus
Salut,

pour lire c'est le module Spreadsheet::ParseExcel qu'il faut utiliser
Ajouter un commentaire
Réponse
+0
moins plus
comment lire le fichier xls?
et merci bcp
Ajouter un commentaire
Réponse
+0
moins plus
bonjour, je travaille avec vista et office 2007, problème: j'ouvre un fichier excel, l'enregistre, il apparait dans document,
si je veux l'ouvrir, windows me répond qu'il ne trouve pas le document xlsx, que faire??
merci d'avance
Ajouter un commentaire
Ce document intitulé « [PERL] lire contenu fichier .xls » issu de CommentCaMarche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.
Dossier à la une
5 extensions si vous voulez revenir à l'ancien Facebook