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

Access Discussion :

Comment convertir une heure au format AM/PM en format 24 heures ? [AC-2010]


Sujet :

Access

  1. #1
    Membre à l'essai
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Août 2014
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information

    Informations forums :
    Inscription : Août 2014
    Messages : 20
    Points : 18
    Points
    18
    Par défaut Comment convertir une heure au format AM/PM en format 24 heures ?
    Bonjour,

    Je cherche à obtenir uniquement l'heure à partir d'un enregistrement "hh:mm:ss a.m/p.m".

    Exemple : 08:21:18 a.m -> 8 ; 08:21:18 p.m -> 20.

    J'ai une table Access 2010 contenant un champs DHeure avec pour donnée "08:21:18 p.m" au format texte (Je ne peux pas changer le type dans la base, je l'importe d'une autre application).

    J'utilise dans une requête la fonction heure() comme suit : Heure([DHeure]) mais j'ai le message #Erreur.

    Si je supprime manuellement la partie a.m ou p.m (08:21:18) directement dans le résultat de la requête, la fonction Heure me renvoie bien l'heure (sans les minutes et les secondes), par contre, je ne sais pas si c'est AM ou PM.

    Comment faire pour récupérer uniquement la partie heure au format 24H ?

    Merci

  2. #2
    Expert éminent

    Homme Profil pro
    Inscrit en
    Mai 2012
    Messages
    3 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations forums :
    Inscription : Mai 2012
    Messages : 3 840
    Points : 7 974
    Points
    7 974
    Par défaut
    Bonjour,

    Une fonction VBA devrait faire l'affaire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Public Function convAMPM_Heure24H(prDate As String) As Date
    If Mid(prDate, 10, 1) = "p" Then
        convAMPM_Heure24H = DateAdd("h", 12, CDate(Left(prDate, 8)))
    Else
        convAMPM_Heure24H = CDate(Left(prDate, 8))
    End If
    End Function
    Tu peux l'interpréter directement comme source d'un champ avec les fonctions VRAIFAUX, GAUCHE, AjjDate et CDate.

    Cordialement,
    Mandresy
    "Je ne sais qu'une chose, c'est que je ne sais rien" Socrate

    N'oublions pas de mettre quand on a trouvé notre bonheur. Soyons sympa pour les futurs heureux.

    Merci, c'est toujours sympa de recevoir des de votre part

  3. #3
    Membre à l'essai
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Août 2014
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information

    Informations forums :
    Inscription : Août 2014
    Messages : 20
    Points : 18
    Points
    18
    Par défaut
    Bonsoir,

    Merci Madefemere, je vais adapter ta solution qui me convient d'avantage que celle que j'ai mise en place entre temps, bien que similaire mais je cherchais plutôt une fonction VBA.

    Pour info, voici le code SQL de ma procédure :

    SELECT MEquipoUso.DFecha, MEquipoUso.DHora, MEquipoUso.DTEquipo, MEquipoUso.DNumEquipo, Year([DFecha]) AS Año, DatePart("ww",[DFecha],2) AS Semana, Weekday([DFecha],2) AS Dia, Left([Dhora],2) AS H12, Right([Dhora],3) AS AMPM, IIf([AMPM]="p.m",[H12]+12,[H12]) AS H24
    FROM MEquipoUso
    WHERE (((MEquipoUso.DTEquipo)="S") AND ((Year([DFecha]))=2015) AND ((DatePart("ww",[DFecha],2))=24));

    Cordialement,

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

Discussions similaires

  1. Comment convertir une date MySQL au format francophone ?
    Par bilane dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 11/09/2006, 10h44
  2. Réponses: 14
    Dernier message: 29/06/2005, 10h22
  3. Comment convertir une heure (TDateTime) locale en UTC/GMT
    Par rconty dans le forum C++Builder
    Réponses: 2
    Dernier message: 16/05/2005, 10h49
  4. Réponses: 6
    Dernier message: 14/02/2004, 14h01
  5. Réponses: 3
    Dernier message: 28/09/2003, 10h46

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