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 :

Avoir le temps d'un traitment via la commande time


Sujet :

Shell et commandes GNU

  1. #1
    Invité
    Invité(e)
    Par défaut Avoir le temps d'un traitment via la commande time
    Bonjour,

    Je cherche a optimiser un traitement. Pour cela, j'essaye de récupérer le temps utilisé.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $ time date
    sam. 19 janv. 2013 16:26:54
     
    real    0m0.031s
    user    0m0.000s
    sys     0m0.015s
    J'ai trouvé ces info:
    - real correspond au temps réel de la tâche.
    - user correspond au temps utilisateur, c’est à dire le temps CPU utilisé par le programme utilisateur
    - sys définit le temps système, cela correspond au temps utilisé par le système pour gérer l’exécution de la tâche.
    Si j'ai bien compris:
    - le "real" correspond au temps entre le début et la fin de la commande.
    - le "user" + "sys" donnerais le vrai temps de la commande (indépendant de ce qu'on fait à côté).

    J'ai fais quelque test en regardant ou non une vidéo sur youtube en même temps. user et sys sont toujours plus élevé quand j'utilise youtube ... Ca ne devrait pas être constant (j'utilisais exactement la même commande et les mêmes données avec cygwin sous windows) ?

    Il y a-t-il un moyen de récupérer user+sys directement avec une des options de time? Je n'ai rien trouvé ...

    Merci.

  2. #2
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 832
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

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

    Informations forums :
    Inscription : Février 2006
    Messages : 12 832
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Beginner.j Voir le message
    Il y a-t-il un moyen de récupérer user+sys directement avec une des options de time? Je n'ai rien trouvé ...

    Merci.
    time -f "%U %S"...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  3. #3
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    time -f "%U %S"...
    Ca ne marche pas chez moi ...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $ time -f "%U %S" date
    bash: -f : commande introuvable
     
    real    0m0.015s
    user    0m0.000s
    sys     0m0.000s

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 654
    Par défaut
    attention, bash possède un mot clé time, qui ne comprend pas d'autres options que -p, sur Debian, il faudra indiquer le chemin vers la commande [codeinlline]time[/codeinlline] (/usr/bin/ ?) pour «désambiguïser».

    en BASH
    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    TIME="%U+%S" time commande 2> >(bc)
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  5. #5
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par N_BaH Voir le message
    attention, bash possède un mot clé time, qui ne comprend pas d'autres options que -p, sur Debian, il faudra indiquer le chemin vers la commande [codeinlline]time[/codeinlline] (/usr/bin/ ?) pour «désambiguïser».

    en BASH
    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    TIME="%U+%S" time commande 2> >(bc)
    Merci ça fonctionne.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $ TIME="%U+%S" time date 2> >(bc)
    dim. 20 janv. 2013 14:28:26
    .01
    Le "2> >(bc)" sert à rediriger le résultat de la commande time vers la commande bc, c'est bien ça? J'ai du mal à comprendre comment ça fonctionne ...

  6. #6
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 832
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

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

    Informations forums :
    Inscription : Février 2006
    Messages : 12 832
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par N_BaH Voir le message
    attention, bash possède un mot clé time, qui ne comprend pas d'autres options que -p, sur Debian, il faudra indiquer le chemin vers la commande [codeinlline]time[/codeinlline] (/usr/bin/ ?) pour «désambiguïser».
    Me semble que faire précéder la commande d'un backslash permet aussi de «désambiguïser» sans avoir à fournir le chemin
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    \time -f "%S %U" date
    dimanche 20 janvier 2013, 14:55:48 (UTC+0100)
    0.00 0.00
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  7. #7
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Me semble que faire précéder la commande d'un backslash permet aussi de «désambiguïser» sans avoir à fournir le chemin
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    \time -f "%S %U" date
    dimanche 20 janvier 2013, 14:55:48 (UTC+0100)
    0.00 0.00
    Effectivement, cela marche aussi.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Import d'une table temp et ouverture formulaire via VBA
    Par Access_ible dans le forum VBA Access
    Réponses: 4
    Dernier message: 01/09/2009, 11h44
  2. Changer en temps réel paramètre block via GUI
    Par Bassmax dans le forum Simulink
    Réponses: 4
    Dernier message: 23/12/2008, 20h55
  3. Avoir la télé sur son pc via la freebox
    Par griese dans le forum Hardware
    Réponses: 6
    Dernier message: 26/03/2007, 13h26
  4. N'avoir que les noms de fichier via la commande ls -l
    Par fde_amadeus dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 26/10/2006, 18h33
  5. Réponses: 5
    Dernier message: 03/08/2006, 16h13

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