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

Macros et VBA Excel Discussion :

Mettre en forme une date sous le format "dd/mm/yy"


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Employé administratif
    Inscrit en
    Février 2014
    Messages
    78
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Employé administratif

    Informations forums :
    Inscription : Février 2014
    Messages : 78
    Par défaut Mettre en forme une date sous le format "dd/mm/yy"
    Bonjour,

    Dans une même colonne, j'ai des dates sous le format (annéemoisjour).

    Exemple : 20190211

    Je souhaiterais modifier ces dates à l'aide de VISUAL BASIC au format "dd/mm/yy", mais je n'y parviens pas.

    Quelqu'un peut-il m'aider ?

    Merci beaucoup pour votre aide.

  2. #2
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    En supposant que tes dates soient en colonne A et commencent en ligne 2, tu mets dans une autre cellule de la ligne 2 la formule :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =DATE(GAUCHE(A2;4);STXT(A2;5;2);STXT(A2;7;2))
    Tu copies vers le bas autant que nécessaire.
    Tu fais un "copier / coller valeur" de cette colonne vers ta colonne de dates.

    Pour faire la même chose en VBA, utiliser les fonctions DateSerial(), Left() et Mid() qui sont les équivalents de celles utilisées dans ma formule.
    Le tout dans une boucle For To.

  3. #3
    Membre confirmé
    Homme Profil pro
    Employé administratif
    Inscrit en
    Février 2014
    Messages
    78
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Employé administratif

    Informations forums :
    Inscription : Février 2014
    Messages : 78
    Par défaut Mettre en forme une date sous le format "dd/mm/yy" à l'aide de VBA
    Bonjour

    Pour faire la même chose avec VBA, j'ai rédigé :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Range("A2").Formula = DateSerial(Left(A2, 4), Mid(A2, 5, 2), Mid(A2, 7, 2))
    et j'ai une erreur d'exécution.

    Comment corriger ma macro ?

    Merci.

    Cordialement.

  4. #4
    Expert confirmé
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Billets dans le blog
    7
    Par défaut
    Bonjour,

    La propriété Formula se code comme une fonction texte

    = "=....

    Voir cette aide

    Autre possibilité, utiliser l'enregistreur qu'il faudra, bien entendu, épurer.

  5. #5
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Déjà, A2 sans le mettre dans un Range, ce n'est pas une référence de cellule mais une variable.
    Pour éviter ce type d'erreur, prend l'habitude de mettre un "Option Explicit" avant tes codes ou, mieux, fais en sorte que ça se mette tout seul : Menu Outils > Options > Cocher "Déclaration de variables obligatoire"

    Pour en revenir à ton affaire, tu ne peux pas passer par Formula puisque techniquement la formule d'une cellule ne peut pas faire référence à la valeur de cette cellule.
    Il faudrait donc placer le résultat dans une autre cellule.
    Et dans ce cas, il vaudrait mieux utiliser FormulaLocal qui te permettrait de mettre directement la formule que je t'ai donnée.
    Lire ça : https://docs.microsoft.com/fr-fr/off...e.formulalocal
    Mais je ne vois pas trop l'intérêt que ça aurait de développer une macro pour ça.

    Le plus simple serait de mettre directement la valeur dans la cellule :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Range("A2").Value = DateSerial(Left(Range("A2"), 4), Mid(Range("A2"), 5, 2), Mid(Range"A2"), 7, 2))
    Sans oublier (quelle que soit la solution retenue) de passer ta cellule au format date avec la propriété NumberFormat du Range.
    Lire ça : https://msdn.microsoft.com/fr-fr/lib...1(v=office.15)

Discussions similaires

  1. Mettre en forme une date
    Par francois78 dans le forum SQL
    Réponses: 17
    Dernier message: 22/12/2011, 14h19
  2. [Dates] Mettre en forme une date
    Par joboy84 dans le forum Langage
    Réponses: 4
    Dernier message: 28/05/2009, 14h29
  3. Réponses: 1
    Dernier message: 19/08/2008, 21h13
  4. Réponses: 5
    Dernier message: 08/03/2006, 15h22
  5. [JDBC] Requête avec une date sous la forme dd/MM/yyyy
    Par sylviefrfr dans le forum JDBC
    Réponses: 6
    Dernier message: 12/11/2005, 09h35

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