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/décomptes heures entre 2 créneaux


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Janvier 2023
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Charente (Poitou Charente)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Janvier 2023
    Messages : 4
    Par défaut Calcul/décomptes heures entre 2 créneaux
    Bonjour à tous,

    Voilà plusieurs jours que je bloque sur une fonction de décomptes horaires, voilà j'ai deux datetime (début et fin) et j'aimerais calculer les nombres d'heures effectuées selon des créneaux définis.
    C'est à dire entre ces deux datetime savoir combien de temps il y a eu le matin (05h / 11h) le midi (11h / 14h) l'apres-midi (14h / 19h) et la nuit (19h / 05h).
    Malgré différentes méthodes de boucle sur mes datetime je suis confronté à la difficulté dés que les jours début et fin sont différents.
    Si quelqu'un à une piste, je suis preneur.

    Merci...

  2. #2
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 762
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 762
    Par défaut
    Salut,

    Citation Envoyé par xavro17 Voir le message
    Si quelqu'un à une piste, je suis preneur.
    Le module datetime sait faire la différence entre 2 dates pour en faire un timedelta où récupérer le nombre de jours/secondes à recalculer en heures.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 840
    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 840
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par xavro17 Voir le message
    Voilà plusieurs jours que je bloque sur une fonction de décomptes horaires
    Plusieurs jours...

    Citation Envoyé par xavro17 Voir le message
    C'est à dire entre ces deux datetime savoir combien de temps il y a eu le matin (05h / 11h) le midi (11h / 14h) l'apres-midi (14h / 19h) et la nuit (19h / 05h).
    Si quelqu'un à une piste, je suis preneur.
    Ta question manque de précision. Un datetime, comme son nom l'indique, c'est une date + une time. Or tu ne montres toi que des times. As-tu la date qui va avec??? Dans ce cas ça semble assez simple
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    >>> from datetime import datetime
    >>> d=datetime(2023, 1, 13, 5, 30)
    >>> d
    datetime.datetime(2023, 1, 13, 5, 30)
    >>> str(d)
    '2023-01-13 05:30:00'
    >>> f=datetime(2023, 1, 13, 6, 20)
    >>> f
    datetime.datetime(2023, 1, 13, 6, 20)
    >>> str(f)
    '2023-01-13 06:20:00'
    >>> (f-d).seconds
    3000
    Ne reste plus qu'à décider si 3000 secondes comptent ou ne comptent pas pour 1h.
    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]

  4. #4
    Futur Membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Janvier 2023
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Charente (Poitou Charente)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Janvier 2023
    Messages : 4
    Par défaut
    Bonjour,

    Merci pour vos réponse,

    Plusieurs jours...=> oui mais pas 24h/24h


    Ta question manque de précision. Un datetime, comme son nom l'indique, c'est une date + une time. Or tu ne montres toi que des times. As-tu la date qui va avec??? Dans ce cas ça semble assez simple
    => Désolé de mon manque de précision...Je vous mets un exemple :
    début : "2023-01-12 05:00"
    fin : "2023-01-13 03:15"

    je dois calculer par chaque créneau horaire durant toute la période, le nombre d'heure effectuée:
    - le matin donc ("2023-01-12 05:00" => "2023-01-12 11:00")
    - le midi donc ("2023-01-12 11:00" => "2023-01-12 14:00")
    - l'apres-midi donc ("2023-01-12 14:00" => "2023-01-12 19:00")
    - la nuit donc ("2023-01-12 19:00" => "2023-01-13 03:15")

    En espérant être plus clair dans ma demande.

  5. #5
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 840
    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 840
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par xavro17 Voir le message
    Plusieurs jours...=> oui mais pas 24h/24h
    Là c'est plus sincère

    Citation Envoyé par xavro17 Voir le message
    En espérant être plus clair dans ma demande.
    Ben... c'est mieux mais pas encore assez. Par exemple pourquoi tu détailles "matin+midi+après-midi+soir" ? Peut pas simplement dire 3h15(j+1) - 5h00(j)=22h15 ???
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    >>> d=datetime(2023, 1, 12, 5, 0)
    >>> f=datetime(2023, 1, 13, 3, 15)
    >>> (f-d).seconds
    80100
    >>> (f-d).seconds/3600
    22.25
    >>>
    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]

  6. #6
    Futur Membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Janvier 2023
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Charente (Poitou Charente)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Janvier 2023
    Messages : 4
    Par défaut
    En faite j'ai besoin de détaillé "matin+midi+après-midi+soir" car c'est ces données dont j'ai besoin en résultat et pas seulement le nombre d'heure totale.
    Pour exemple si j'ai une plage horaire de :
    -"2023-01-12 05:00 à 2023-01-13 03:15" il me faut en résultat => matin : 6h, midi: 3h, ap-midi: 5h et nuit 8h15"
    -"2023-01-12 05:00 à 2023-01-12 14:15" il me faut en résultat => matin : 6h, midi: 3h, ap-midi: 0h15min et nuit 0h00"

    Avec des exemples, peut-être plus claire.

  7. #7
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 762
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 762
    Par défaut
    Citation Envoyé par xavro17 Voir le message
    En faite j'ai besoin de détaillé "matin+midi+après-midi+soir" car c'est ces données dont j'ai besoin en résultat et pas seulement le nombre d'heure totale.
    Là ce n'est plus une question Python mais d'algo: comment mettre en forme vos données et imaginer un pseudo-code qui va avec.
    Vous avez le forum algo. pour çà.

    Puis sachant comment faire çà, il y aura peut être des questions pour le coder avec python.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  8. #8
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 840
    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 840
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par xavro17 Voir le message
    Avec des exemples, peut-être plus claire.
    Oui de plus en plus. Peut-être dire quand finit la nuit...???

    Mais bon déjà là ça suffit pour démarrer. Moi je partirais sur un dico de ce style
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    periode={
    	"matin" : (8, 11),
    	"midi" : (11, 14),
    	"après-midi" : (14, 19),
    	"nuit" : (19, 8),
    }
    Avec
    1. définir la période où commence le travail
    2. définir la période où termine le travail
    3. pour ces deux périodes précises, calculer l'écart horaire qui va bien
    4. pour les périodes intermédiaires, l'écart horaire est déjà donné
    5. assembler le tout pour donner une jolie liste


    Ainsi les périodes sont évolutives (on peut rajouter le goûter, l'apéro, le souper, etc). Faut juste que les début et fin de chaque tranche se joignent correctement et qu'il n'y ait aucun trou (on peut même rajouter un chek sur ce détail), le reste n'est qu'affaire de boucle.
    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]

  9. #9
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 762
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 762
    Par défaut
    Citation Envoyé par xavro17 Voir le message
    En espérant être plus clair dans ma demande.
    c'est pas comme demander de se faire livrer des pizzas: vous êtes supposé programmer et venez ici pour essayer de vous améliorer... donc montrer ce que vous avez essayé de faire et expliquer ce qui vous bloque pour aller plus loin est un minimum...
    Car si on suppose que vous sachiez multiplier, diviser,... je ne vois pas trop ce qui vous bloque.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

Discussions similaires

  1. Réponses: 5
    Dernier message: 01/02/2017, 15h51
  2. [XL-2003] Recherche d'une formule de calcul d'heure entre 2 dates
    Par Micky58 dans le forum Excel
    Réponses: 6
    Dernier message: 13/01/2014, 09h30
  3. [XL-2003] Calculer les heures entre 2 dates
    Par Neptune64 dans le forum Excel
    Réponses: 3
    Dernier message: 30/12/2009, 22h49
  4. [XL-2003] calcul d'heure entre deux date et heure
    Par fullmetalknet dans le forum Excel
    Réponses: 8
    Dernier message: 06/11/2009, 11h49
  5. calculer nombre heure entre 2 dates
    Par liquid dans le forum VB 6 et antérieur
    Réponses: 11
    Dernier message: 20/03/2007, 19h48

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