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

Python Discussion :

calcul de temps


Sujet :

Python

  1. #1
    Nouveau membre du Club
    Inscrit en
    Mars 2008
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 27
    Points : 26
    Points
    26
    Par défaut calcul de temps
    Bonjour;
    je voulais récupérer un champs de type "time" d'une table postgresql pour l'utiliser ensuite dans un calcul de temps.
    la requête de sélection renvoi les valeurs en <type datetime.time> , hors que ce type de donnée ne supporte pas les opérations mathématiques telle que l'opérande "-" .
    ce type renvoi un format telle que : "10:14:04"
    comment faire pour pouvoir calculer la différence entre plusieurs heures et ensuite le cumul des différences ?

    Merci d'avance

  2. #2
    Membre éclairé
    Homme Profil pro
    heu...
    Inscrit en
    Octobre 2007
    Messages
    648
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : heu...

    Informations forums :
    Inscription : Octobre 2007
    Messages : 648
    Points : 773
    Points
    773
    Par défaut
    tu peux créer une fonction qui converti ce format d'heure, en seconde, et une autre qui converti des secondes dans ce format d'heures, ça te permettera de calculer tes différence d'heure facilement

  3. #3
    Nouveau membre du Club
    Inscrit en
    Mars 2008
    Messages
    27
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 27
    Points : 26
    Points
    26
    Par défaut
    Bonjour;
    merci pour l'aide. j'ai trouvé une solution qui ressemble un peu à ce que vous avez proposé; en fait l'utilisation du type "datetime.datetime" au lieu du type "datetime.time" permet de faire la soustraction entre deux "datetime" et ça retourne un <type 'datetime.timedelta'> sous la forme hh:mm:ss ce qui peut être converti en nombre entier présentant ce "timedelta" en secondes. le calcul de cumul des différences en seconde peut être formater en hh:mm avec une simple fonction que j'ai fait à part .
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    heur1 = datetime.datetime(1, 1, 1, hh, mm, ss)
    heur2 = datetime.datetime(1, 1, 1, hh, mm, ss)
    diff1 = heur2 - heur1 ##__diff1 est de <type 'datetime.timedelta'> 
    diff1.seconds ##__retourne la différence en secondes, ça aide lorsque on a plusieurs différences qu'on veut calculer la somme car le <type 'datetime.timedelta'>  ne supporte pas l'addition
    ##__une simple fonction de conversion telle que la suivante nous donne le format initial
    def secondes_to_datetime(self, secondes):
            res = ''
            heur = int(secondes)/3600
            min = (int(secondes)%3600) / 60
            res = str(heur) +':'+ str(min)
            return res
    ça marche

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

Discussions similaires

  1. comment calculer le temps d'execution
    Par passion_info dans le forum C++Builder
    Réponses: 1
    Dernier message: 09/06/2005, 10h13
  2. Calculer le temps passé
    Par Joeleclems dans le forum MFC
    Réponses: 4
    Dernier message: 29/04/2005, 10h40
  3. calculer le Temp écoulé
    Par ada_b dans le forum SQL
    Réponses: 1
    Dernier message: 30/11/2004, 10h44
  4. [MFC] : CTime ? Calcul de temps d'éxécution
    Par jonzuzu dans le forum MFC
    Réponses: 10
    Dernier message: 25/05/2004, 15h22
  5. Réponses: 8
    Dernier message: 18/09/2002, 04h20

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