Rechercher : dans
Par :

Parser fichier txt en PERL

Dernière réponse le 13 mar 2007 à 09:13:04 KrSt, le 12 mar 2007 à 16:11:16 
 Signaler ce message aux modérateurs

Bonjour !
J'ai pour but de récuperer les données d'un fichier texte pour pouvoir par la suite les inserer dans une base de données.

Voici un exemple du type de fichier que je souhaite parser:

root@desktop:/data/hey# tail -n 20 tmp/erf/253158/ofi/txt
2007:02:18;14:55;AG4561_2;192.168.0.27;ok
2007:02:18;15:25;Serveur_X12;192.168.0.231;ok

etc etc ..


L'ennui c'est que je n'y connais rien à PERL... Voila ou j'en suis pour l'instant :

#!/usr/bin/perl -w
use strict;
print "Content-type: text/html\n\n";
open FICHIER,"< monfichier.log" or die "Le fichier n'existe pas !";
while ($ligne = <FICHIER>)
{
if($ligne =~ ( chaine de recherche que je ne sais pas ecrire )
  {
    my $date = $1;
    my $heure = $2;
    my $elem = $3;
    my $adIP = $4;
    my $statut = $5;
}
}
close FICHIER;


Voila donc je veux récuperer chaque élément qui m'interresse du fichier dans une variable... Le probleme c'est que je ne sais pas écrire la chaine de recherche correspondante ..

Voila, si quelqu'un à une idée c'est tres volontier !
Configuration: Windows XP
Internet Explorer 6.0

Meilleures réponses pour « Parser fichier txt en PERL » dans :
Fichier TXT Voir Format TXT Un fichier TXT est un fichier texte, c'est-à-dire un simple fichier contenant du texte au format ASCII. Pour ouvrir ou modifier un tel fichier, il suffit d'utiliser le bloc-notes ou un éditeur de texte traditionnel.
[MS-Dos] Ecrire dans un fichier texte en batch VoirPour écrire dans un fichier texte, il suffit d'utiliser une redirection ">" : echo texte_à_ecrire > fichier_de_sortie.txt Pour écrire à la fin d'un texte existant (concaténation) : echo "écriture a la fin du fichier ">>...

1

lami20j, le 12 mar 2007 à 16:20:26
  • +3

Il faut préciser ce que tu veux faire avec les variables

Voilà ton code un peu modifier

#!/usr/bin/perl
use strict;use warnings;


open FICHIER,"< monfichier.log" or die "E/S : $!\n";
while (my $ligne = <FICHIER>){
    my ($date,$heure,$elem,$adIP,$statut) = split /;/,$ligne;
    # traitment des variables
    .....
    .....
}
close FICHIER;
lami20j

Répondre à lami20j

2

KrSt, le 12 mar 2007 à 16:49:47

Wow ! Merci pour la rapidité de réponse !

En fait je veux inserer le contenu des variables dans une base MySQL ...

J'avais continué à modifier mon code entre temps :

#!/usr/bin/perl -w
use strict;
use DBI;
use CGI;
my($cgi) = new CGI;
print "Content-type: text/html\n\n";

open FICHIER,"< monfichier.log" or die "Le fichier n'existe pas !";
while ($ligne = <FICHIER>)
{
if($ligne =~ ( chaine de recherche que je ne sais pas ecrire )
  {
    my $date = $1;
    my $heure = $2;
    my $elem = $3;
    my $adIP = $4;
    my $statut = $5;
}
}

#Connection à la base de données mysql NomBase
my $db = DBI -> connect (("dbi:mysql:dbname=NomBase;host=localhost;","root","******")) or die "connection impossible!";

#recuperation puis insertion d une donnee
my($date) = $cgi->param("date");
my($heure) = $cgi->param("heure");
my($elem) = $cgi->param("elem");
my($adIP) = $cgi->param("IP");
my($statut) = $cgi->param("Statut");

$db->do("insert into client values ('$date', '$heure', '$elem', '$adIP', '$statut');")|| die "pb de requete : $DBI::errstr";

close FICHIER;


Voila, donc je ne sais pas si la syntaxe est exacte vu que c'est mon premier code en PERL, mais ce qui me pose le plus de probleme c'est la recherche pour recuperer les differents element du fichier texte (adresse ip etc ... )

Répondre à KrSt

3

lami20j, le 12 mar 2007 à 19:09:10

Je ne comprends pas très bien ce que tu veux.

Si tu veux utiliser les valeurs contenus dans ton fichier, pourquoi tu récupères les données depuis un formulaire.

Il faut faire le traitement dans la boucle pour chaque ligne.
Donc tu te connectes à ta base avant la boucle while, et enusite tu applique le traitement pour chaque ligne.

Juste un exemple pour me faire comprendre

#!/usr/bin/perl

use strict;use warnings;
my ($date,$heure,$elem,$adIP,$statut);

while (my $ligne = <DATA>){
($date,$heure,$elem,$adIP,$statut) = split /;/,$ligne;
# dans la boucle on lit chaque ligne
# et ensuite j'affiche le contenu de variables
  print "***** DANS LA BOUCLE *****\n";
  print "\$date  : $date\n";
  print "\$heure : $heure\n";
  print "\$elem  : $elem\n";
  print "\$adIP  : $adIP\n";
  print "\$statut: $statut\n";
}

# à l'exterieur de la boucle
# on affiche seulement la dernière ligne
# le trataitement il faut l'exécuter dans la boucle
  print "===== A L'EXTERIEUR DE LA BOUCLE =====\n";
  print "\$date  : $date\n";
  print "\$heure : $heure\n";
  print "\$elem  : $elem\n";
  print "\$adIP  : $adIP\n";
  print "\$statut: $statut\n";
__END__
2007:02:18;14:55;AG4561_2;192.168.0.27;ok
2007:02:18;15:25;Serveur_X12;192.168.0.231;ok
lami20j

Répondre à lami20j

4

lami20j, le 12 mar 2007 à 19:22:22

Ca doit être quelque chose comme ça

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

my $cgi = new CGI;
my ($date,$heure,$elem,$adIP,$statut);

print "Content-type: text/html\n\n";

open FICHIER,"< monfichier.log"
    or die "Le fichier n'existe pas ! : $!\n";

#Connection à la base de données mysql NomBase
my $db = DBI -> connect (("dbi:mysql:dbname=NomBase;host=localhost;","root","******"))
                or die "connection impossible!";

while ($ligne = <FICHIER>){
# récupération des éléments
 ($date,$heure,$elem,$adIP,$statut) = split /;/,$ligne;
# et on insere dans la base
  $db->do("insert into client values ('$date', '$heure', '$elem', '$adIP', '$statut')");
          or die "pb de requete : $DBI::errstr";
}# fin de traitement de fichier
close FICHIER;

Tu n'as pas besoin de
if($ligne =~ ( chaine de recherche que je ne sais pas ecrire )
split est suffisant vu que les données sont séparées par point-virgule lami20j

Répondre à lami20j

5

lami20j, le 12 mar 2007 à 19:33:44

Salut,

dans ton cas je pense que c'est suffisant d'utiliser

LOAD DATA INFILE 'ton_fichier' INTO TABLE nom_de_table FIELDS TERMINATED BY ';'

lami20j

Répondre à lami20j

6

 KrSt, le 13 mar 2007 à 09:13:04
  • +1

Merci beaucoup pour ton aide !
Je devrais pouvoir m'en sortir avec tout ça :-)

Je n'ai pas la possibilité de tester maintenant mais à priori ça colle parfaitement à ce que je cherchais.

Merci bien !

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

my $cgi = new CGI;
my ($date,$heure,$elem,$adIP,$statut);

print "Content-type: text/html\n\n";

open FICHIER,"< monfichier.log"
    or die "Le fichier n'existe pas ! : $!\n";

#Connection à la base de données mysql NomBase
my $db = DBI -> connect (("dbi:mysql:dbname=NomBase;host=localhost;","root","******"))
                or die "connection impossible!";

while ($ligne = <FICHIER>){
# récupération des éléments
 ($date,$heure,$elem,$adIP,$statut) = split /;/,$ligne;
# et on insere dans la base
  $db->do("insert into client values ('$date', '$heure', '$elem', '$adIP', '$statut')");
          or die "pb de requete : $DBI::errstr";
}# fin de traitement de fichier
close FICHIER;

Répondre à KrSt
Collection CommentÇaMarche.net