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

Excel Discussion :

Remplacer : par h dans formule [XL-2016]


Sujet :

Excel

  1. #1
    Membre du Club
    Homme Profil pro
    Mécanicien avion
    Inscrit en
    Février 2018
    Messages
    146
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Mécanicien avion

    Informations forums :
    Inscription : Février 2018
    Messages : 146
    Points : 45
    Points
    45
    Par défaut Remplacer : par h dans formule
    Bonjour à tous,

    J’ai fait une formule pour calculer mes heures sur des journées de 8h
    Code formule : Sélectionner tout - Visualiser dans une fenêtre à part
    =ENT(Z37/(1/24*8))&" jour(s) "&TEXTE(Z37-ENT(Z37/(1/24*8))*(1/24*8);"hh:mm")

    J’aimerais mettre un h à la place des : et je n’y arrive pas....
    Y a t’il une astuce à faire dans ma formule ?
    Ou alors je suis de mettre un code vba remplace : par h dans a1 ? (Si c’est le cas, auriez-vous un code à me transmettre s’il vous plaît ?)

    Je sèche et trouve rien....

    Merci à tous et bonne soirée

  2. #2
    Membre averti
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Janvier 2012
    Messages
    271
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2012
    Messages : 271
    Points : 331
    Points
    331
    Par défaut
    Bonsoir,

    Peut-être de cette façon, ou alors j'ai rien compris avec tes :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =ENT(Z37/(1/24*8))&" jour(s) "&TEXTE(Z37-ENT(Z37/(1/24*8))*(1/24*8);"hh")& " heures"
    Slts

  3. #3
    Membre du Club
    Homme Profil pro
    Mécanicien avion
    Inscrit en
    Février 2018
    Messages
    146
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Mécanicien avion

    Informations forums :
    Inscription : Février 2018
    Messages : 146
    Points : 45
    Points
    45
    Par défaut
    Si c’est l’idée.... d’ailleurs j’ai mis à la suite de ton code &*MINUTE(.....,"mm")

    Le problème c’est que moins de 10 minutes ça me met 1,2,....9
    Et non 01,02,....,09,10,....59

  4. #4
    Membre expert Avatar de QuestVba
    Homme Profil pro
    Enseignant
    Inscrit en
    Juillet 2012
    Messages
    2 477
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2012
    Messages : 2 477
    Points : 3 864
    Points
    3 864
    Par défaut
    Hello,
    Comme je ne suis certain de bien visualiser tes données, voici une possibilité à adapter :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    =SI(ENT(Z37/(1/24*8))=0;"";SI(ENT(Z37/(1/24*8))=1;ENT(Z37/(1/24*8))&" jour ";ENT(Z37/(1/24*8))&" jours "))
    & " " & SI(TEXTE(Z37-ENT(Z37/(1/24*8))*(1/24*8);"hh")="00";"";SI(CNUM(TEXTE(Z37-ENT(Z37/(1/24*8))*(1/24*8);"hh"))=1;TEXTE(Z37-ENT(Z37/(1/24*8))*(1/24*8);"hh")&" heure";TEXTE(Z37-ENT(Z37/(1/24*8))*(1/24*8);"hh")&" heures"))
    & " " & SI(MINUTE(Z37)=0;"";SI(MINUTE(Z37)=1;"0"&MINUTE(Z37)&" minute";SI(MINUTE(Z37)<10;"0"&MINUTE(Z37)&" minutes";MINUTE(Z37)&" minutes")))

  5. #5
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 772
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 772
    Points : 28 633
    Points
    28 633
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    J’ai fait une formule pour calculer mes heures sur des journées de 8h
    Pour calculer les heures prestées, je me contente de faire une simple soustraction et ensuite d'en faire la somme. Le tout formaté à l'aide d'un format nombre donc avant de vous donner une réponse pertinente, il serait intéressant de connaître la manière dont vous encodez vos heures
    Faut-il vraiment comptabiliser des secondes pour des heures prestées ? Je peux le comprendre pour un sportif mais pour du travail ????
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  6. #6
    Membre averti
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Janvier 2012
    Messages
    271
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2012
    Messages : 271
    Points : 331
    Points
    331
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    =SI(ENT(Z37/(1/24*8))=0;"";SI(ENT(Z37/(1/24*8))=1;ENT(Z37/(1/24*8))&" jour ";ENT(Z37/(1/24*8))&" jours "))
    & " " & SI(TEXTE(Z37-ENT(Z37/(1/24*8))*(1/24*8);"hh")="00";"";SI(CNUM(TEXTE(Z37-ENT(Z37/(1/24*8))*(1/24*8);"hh"))=1;TEXTE(Z37-ENT(Z37/(1/24*8))*(1/24*8);"hh")&" heure";TEXTE(Z37-ENT(Z37/(1/24*8))*(1/24*8);"hh")&" heures"))
    & " " & SI(MINUTE(Z37)=0;"";SI(MINUTE(Z37)=1;"0"&MINUTE(Z37)&" minute";SI(MINUTE(Z37)<10;"0"&MINUTE(Z37)&" minutes";MINUTE(Z37)&" minutes")))
    Bonjour QuestVba

    Bravo!!

    Slts

  7. #7
    Membre du Club
    Homme Profil pro
    Mécanicien avion
    Inscrit en
    Février 2018
    Messages
    146
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Mécanicien avion

    Informations forums :
    Inscription : Février 2018
    Messages : 146
    Points : 45
    Points
    45
    Par défaut
    Salut,

    Merci pour ton aide, je me suis énormément inspiré de ta formule et les idées de celle-ci pour arriver à mon résultat final...
    Un grand merci pour ton aide, comme à chaque fois sur ce forum, il y a de vrai crack ! Un grand bravo
    Du coup pour mieux me comprendre et plus simple pour moi, j'ai fait en 5 étapes. Je vous donne le dérouler pour les gens qui ont besoin :

    Dans ma case Z37, j'ai la somme de toutes mes heures cumulées
    Étapes 1 à 4 : écriture blanche pour ne pas voir....

    Étape 1 : Formule en AC38
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =ENT(Z37/(1/24*8))+Z37-ENT(Z37/(1/24*8))*(1/24*8)
    Étape 2 : Les jours en U40
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =SI(ENT(Z37/(1/24*8))=0;"";SI(ENT(Z37/(1/24*8))=1;ENT(Z37/(1/24*8))&" jour ";ENT(Z37/(1/24*8))&" jours "))
    Étape 3 : Les heures en U41
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =SI(TEXTE(AH37-ENT(AH37/(8/24))*(8/24);"hh")="00";" 00 H ";SI(AK38<1;TEXTE(AH37-ENT(AH37/(8/24))*(8/24);"hh")&" H ";TEXTE(AH37-ENT(AH37/(8/24))*(8/24);"hh")&"H"))
    Étape 4 : Les minutes en U42
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =SI(MINUTE(MOD(AH37;8/24))=0;"00";SI(MINUTE(MOD(AH37;8/24))<10;"0"&MINUTE(MOD(AH37;8/24));MINUTE(MOD(AH37;8/24))))
    Étape 5 : Résultat en T37
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =SI(AC38=0;"00 H 00";SI(ET(AC38<>ENT(AC38);AC38<1);U41&U42;SI(ET(AC38<>ENT(AC38);AC38>1);U40&U41&U42;U40)))

    Et voila, bonne nuit à tous
    Encore un grand merci

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

Discussions similaires

  1. Caractère & remplacé par &amp; dans mysql
    Par Fullmetal63 dans le forum Langage
    Réponses: 4
    Dernier message: 16/09/2013, 13h19
  2. MySQL remplacé par MariaDB dans Fedora 19 ?
    Par Hinault Romaric dans le forum RedHat / CentOS / Fedora
    Réponses: 20
    Dernier message: 27/03/2013, 14h15
  3. Java remplacé par C# dans Android ?
    Par Hinault Romaric dans le forum Android
    Réponses: 49
    Dernier message: 01/06/2012, 15h13
  4. [AC-2002] Remplacer "," par un "." dans textbox
    Par Chtulus dans le forum VBA Access
    Réponses: 12
    Dernier message: 16/10/2009, 21h24

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