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

Shell et commandes GNU Discussion :

Fonction avec fichier en paramètre


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    157
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 157
    Par défaut Fonction avec fichier en paramètre
    Bonjour,

    1 - Je souhaiterai créer une fonction qui récupère un extrait de log entre 2 horodatages.
    J'ai besoin de votre aide car c'est assez ardu pour moi.

    Le format horaire du log est du type : 24/01/2013 16:13
    imaginons que
    $1=heure_debut
    $2=heure_fin

    2 - Je souhaiterai variabiliser le nom d'entree laissé au choix de l'utilisateur. C'est à dire s'il n'existe pas, le script le créera en lui ajoutant les commentaires.

    3 - Parfois les logs pour une raison ou une autre n'ont pas entièrement loggés, je souhaiterai que si heure_debut renseigné n'existe pas, le script prendra la 1ère ligne .précédente ayant été taggée par une heure. sinon prendre la 1ère ligne du log.

    4 - idem pour heure_fin si n'existe pas prendre 1ère heure suivante taggée sinon allez jusqu'à la fin.

    5 - Enfin est-il possible d'aligner les colonnes du fichier d'entree ?

    Merci d'avance

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    function f1
    {
    
    
    }
    
    egrep -v '^#' liste_fic \
    | while read arg1 arg2 arg3 arg4; do
      f1 $arg1 $arg2 $arg3 $arg4
      done

    J'ai seulement renseigné $1 et $2.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    vi list_fic
    # $1 $2 $3 $4
    #heure_debut heure_fin date contexte
    08 09 $3 $4

  2. #2
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 658
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 658
    Par défaut
    si tu nous exposais ton problème en entier, plutôt que par petits bouts.

    c'est comme si tu nous demandais de peindre ton mur, mais qu'à chaque fois on doive faire le mélange de couleurs; forcément le résultat ne sera pas uniforme; ce sera "moderne" ; "conceptuel"

    mais alors que le mur ne va pas s'écrouler, nos codes peuvent ne pas s'interfacer, être redondant, "anti-optimaux" (?)

    je tiens également à pointer un manque patent de recherches, au niveau algorithmique (il paraît te manquer une vue d'ensemble), et sur internet.
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  3. #3
    Expert confirmé
    Homme Profil pro
    Développeur informatique en retraite
    Inscrit en
    Avril 2008
    Messages
    2 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique en retraite

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 102
    Par défaut
    Citation Envoyé par N_BaH Voir le message
    je tiens également à pointer un manque patent de recherches, au niveau algorithmique (il paraît te manquer une vue d'ensemble), et sur internet.
    Je plussoie et j'ai aussi l'impression que tu n'as pas écrit beaucoup de code pour ton problème... mais il n'est pas trop tard pour t'y mettre!

    Lire les tutoriels, faire des petits essais, tester le comportement des commandes, faire les exercices des tutoriels, etc.

    Sinon, la présentation en couleurs des morceaux de problèmes

  4. #4
    Expert confirmé
    Homme Profil pro
    Développeur informatique en retraite
    Inscrit en
    Avril 2008
    Messages
    2 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique en retraite

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 102
    Par défaut
    Citation Envoyé par amazigh42 Voir le message
    Bonjour,

    1 - Je souhaiterai créer une fonction qui récupère un extrait de log entre 2 horodatages.
    J'ai besoin de votre aide car c'est assez ardu pour moi.
    Allez, j'ai pitié!
    Un indice: regarde du côté de sed :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    $ cat /tmp/plop
    a
    b
    c
    d
    e
    f
    g
    h
    $ sed -n "/c/,/f/p" /tmp/plop
    c
    d
    e
    f
    Si les motifs "c" et "f" contiennent des "/" il faut mettre un \ devant chacun.

  5. #5
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 349
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 349
    Par défaut
    Bonjour,

    Il est vrai que pour le point 1, on peut s'orienter vers sed, mais pour les points 3 et 4, awk est, en mon sens, plus adapté

    Pour l'instant, il manque pas mal d'informations:
    1) l'horodatage, c'est la date + les heures ou juste les heures ?
    2) le fichier de log est il trié par date et heures (dans le cas de programmes "multithreadé" comme jboss par exemple, ce n'est pas le cas) ?
    3) pour le point 5 concernant l'alignement des colonnes, il faudrait savoir a quoi ressemble le fichier d'entrée.
    ...

    Cordialement.

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    157
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 157
    Par défaut
    Bonjour,

    Merci de ton aide.

    1) L'horodatage est sur la date et l'heure voici le formatage d'une ligne [08/02/2013 11:01:32,811] bla bla bla
    2) La rotation des logs est journalière donc la date est fixe, le tri dans le log est fait par l'heure 4 premiers digits.

    3) Le fichier d'entrée ressemble à cela :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    # $1 $2 $3 $4
    # heure_debut heure_fin date contexte
    09 11 08/02/2013 YY

  7. #7
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 349
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 349
    Par défaut
    Bonsoir,

    Il y a encore des zones d'ombres:
    Pour le point 3 (et 4) si on veut par exemple les logs de 09 heures à 11 heures et qu'il n'y a pas de logs sur la plage des 09 heures, est-ce que l'on doit remonter jusqu'à 08:59 (si elle existe) ou jusqu'au plus proche des 08:00 (en admettant que l'on a des logs sur la plage des 08 heures) ?

    De même, peux tu garantir que dans ton fichier de log, il n'y a que des lignes horodatées et seulement des lignes horodatées ?

    Pour l'alignement des colonnes du fichier d'entrée, à priori, celles-ci sont déjà alignées sauf pour tes 2 lignes de commentaires. Si tu veux aligner aussi ces 2 lignes la, il faut que tu respectes le même nombre de colonne, soit en choisissant un autre séparateur que l'espace, soit en supprimant l'espace qui se trouve après le '#', ou soit définissant un nombre de caractère fixe par colonne quitte à faire du remplissage avec des espaces.

    Cordialement.

  8. #8
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    157
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 157
    Par défaut
    Merci de t'être intéressé à mon cas sans condescendance.

    La rotation des logs est journalière.
    L'horodatage concerne le contenu d'un log sur une journée.
    En fait les remontées d'erreur sont horodatées. Une stack erreur peut tenir plusieurs lignes, seule la 1ère d'une même erreur est horodatée.
    Effectivement si dans la journée du 15 janvier si je mets en paramètres 09 et 11H et que 11H n'existe pas, il serait souhaitable de prendre l'heure suivante. Et inversement si 09H n'existe pas, prendre l'heure précédente.

    Concernant le tableau, il s'agissait d'aligner le commentaire correspondant au titre des variables. Je sais ce qu'il faut faire mais pas comment. C'est dire comment créer des espaces pour aligner ?

Discussions similaires

  1. Fonction avec type de paramètre variable
    Par zentaf dans le forum C
    Réponses: 7
    Dernier message: 15/01/2013, 17h32
  2. Macro-fonction avec nombre de paramètres non fixé
    Par miasseu dans le forum Macro
    Réponses: 2
    Dernier message: 31/08/2012, 16h36
  3. fonction avec this en paramètre
    Par bakman dans le forum Débuter
    Réponses: 18
    Dernier message: 07/04/2011, 12h25
  4. fonction avec setTimeOut et paramètres
    Par jeff74 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 31/10/2008, 19h26
  5. besoin d'aide fonction avec fichier (debutant)
    Par boby61 dans le forum Débuter
    Réponses: 9
    Dernier message: 14/03/2005, 11h22

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