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 :

Question sur stat d'un fichier


Sujet :

Langage Perl

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Juin 2009
    Messages
    65
    Détails du profil
    Informations forums :
    Inscription : Juin 2009
    Messages : 65
    Par défaut Question sur stat d'un fichier
    Bonjours,

    Voila j'aimerais savoir pourquoi quand je lance ce 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
    17
    18
    19
    use strict;
     
    my $FicLog = "";
     
    my $Infile = 'C:/partage/MT/am_check_pabxcav.ini';
    open IN, "< $Infile" or die "Can't open $Infile : $!";
    ($FicLog) = <IN>;
    chomp($FicLog);
     
    my $TimeSecond = time();
     
    (my $dev,my $ino,my $mode,my $nlink,my $uid,my $gid,my $rdev,my $size,my $atime,my $mtime,my $ctime,my $blksize,my $blocks) = stat("$FicLog");
    if ($blksize eq 0) {
    	print "ERREUR SUR LA TAIILE DU FICHIER $FicLog";
    	exit 2;
    } elsif ($TimeSecond > ($mtime + 172800)) {	# 172800 = 48 Heures en secondes
    	print "Le fichier a plus de deux jours";
    	exit 2;
    }
    Il me dis que la date a plus de deux jours alors que ce n'est pas vrai. J'ai voulu vérifier ce que contenait la variable $mtime, et elle est vide donc il ne récupère rien du fichier log. Ma seule question : Pourquoi ?

    J'ai pensé que cela pouvais venir du fait que le script ouvre un fichier ini pour trouver le fichier log (l'adresse du fichier log est dans le fichier ini) mais mon problème c'est que je suis obligé de passer par un fichier ini, donc si mon problème vient de là comment faire pour que cela fonctionne ?

    Je vous remercie de votre futur aide

    Ps: Oui je sais, pour ce qui m'ont aidé c'est le même script que la dernière fois sauf que la il me faut la date de modification du fichier, je sais que je suis sur la bonne voie mais il me faut un petit coup de pouce ^^

  2. #2
    Expert confirmé

    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2009
    Messages
    3 577
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2009
    Messages : 3 577
    Par défaut
    Que contient la variable $FicLog ?
    Pourrais-tu vérifier l'existence du fichier $FicLog avant d'utiliser stat ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    if (-f $FicLog) {
      ...
    }
    else {
      die "No file $FicLog found !\n";
    }
    Aparté :
    Pour récupérer le 10e paramètre de stat, tu peux aussi écrire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (undef, undef, undef, undef, undef, undef, undef, undef, undef, my $mtime) = stat($FicLog);
    ou encore :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    my $mtime = (stat($FicLog))[10];

  3. #3
    Membre averti
    Inscrit en
    Juin 2009
    Messages
    65
    Détails du profil
    Informations forums :
    Inscription : Juin 2009
    Messages : 65
    Par défaut
    Ah oui désolé : la variable FicLog contient l'adresse du fichier log donc : C:\partage\MT\1\MT.log

  4. #4
    Expert confirmé

    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2009
    Messages
    3 577
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2009
    Messages : 3 577
    Par défaut
    L'as-tu explicitement vérifié en l'affichant lors de l'exécution du script ? ,en plaçant des caractères de délimitation autour, par exemple comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    print "Fichier : [$FicLog]\n";
    Ensuite, tu ne dis pas ce qui se passe en ajoutant le test que j'ai proposé (-f $FicLog).

  5. #5
    Membre averti
    Inscrit en
    Juin 2009
    Messages
    65
    Détails du profil
    Informations forums :
    Inscription : Juin 2009
    Messages : 65
    Par défaut
    Ok bon ben ton test est bien je fais que des erreurs de débile j'avais créé mon log mais il été en .txt

  6. #6
    Expert confirmé

    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2009
    Messages
    3 577
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2009
    Messages : 3 577
    Par défaut
    Tu devrais utiliser le débugger perl... il est facile d'accès, et permet de détecter des tas de problèmes.

Discussions similaires

  1. Réponses: 11
    Dernier message: 14/05/2009, 20h30
  2. Question sur les inclusions de fichier.
    Par Krishna dans le forum C++
    Réponses: 5
    Dernier message: 22/04/2009, 20h07
  3. {VBA Excel}Question sur la lecture de fichier excel
    Par Thomas69 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 11/12/2007, 09h12
  4. Question sur lecture d'un fichier text en Java
    Par ovcrash dans le forum Entrée/Sortie
    Réponses: 13
    Dernier message: 27/11/2007, 17h14

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