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 :

Inversement de date lors d'une importation [XL-2007]


Sujet :

Macros et VBA Excel

  1. #1
    Membre habitué Avatar de zangaloni
    Profil pro
    Étudiant
    Inscrit en
    Mars 2009
    Messages
    474
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2009
    Messages : 474
    Points : 151
    Points
    151
    Par défaut Inversement de date lors d'une importation
    Bonjour,

    J'importe un tableau de données d'un classeur fermé à un classeur ouvert.
    Ceci à travers l'ouverture ( en code vba) du classeur fermé, et collage du tableau souhaité sur le classeur ouvert.
    Tout se passe bien, sauf que dernièrement , j'ai remarqué que pour certaines dates le mois et le jour sont inversé, pour d'autres non.

    J'ajoute comme information que le fichier fermé est en format 2003 et celui de destination est 2007 ou 2010.

    Une idée de solution ?

  2. #2
    Membre émérite
    Homme Profil pro
    Inscrit en
    Décembre 2011
    Messages
    1 186
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 1 186
    Points : 2 502
    Points
    2 502
    Par défaut
    Bonjour,

    Essayer de forcer le format de la date au moment de l'insertion.
    Format(<la cellule contenant une date>, "dd/mm/yy")Sinon après la relecture, passer un code testant le format de date pour le
    transformer au format français :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Dim r as range
    Dim maDate as Date
    For each r in UsedRange
       If r.NumberFormat = "mm/dd/yyyy" Then
            maDate = r.Value
           r.NumberFormat = "dd/mm/yyyy"
           r.Value = CDate(Month(maDate) & "/" & Day(maDate) & "/" & Year(maDate)) 
       End If
    Next r

  3. #3
    Membre habitué Avatar de zangaloni
    Profil pro
    Étudiant
    Inscrit en
    Mars 2009
    Messages
    474
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2009
    Messages : 474
    Points : 151
    Points
    151
    Par défaut
    Rebonjour,
    Merci pour votre aide,
    j'ai essayé les deux, mais sans résultat.

    Je met en pièce jointe le fichier source apparemment le format des cellules est bizarre.Pièce jointe 90432

  4. #4
    Membre émérite
    Homme Profil pro
    Inscrit en
    Décembre 2011
    Messages
    1 186
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 1 186
    Points : 2 502
    Points
    2 502
    Par défaut
    Re.

    Essayez de convertir la chaîne en date à la lecture :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
      With <cellule destination>
               If IsDate(<cellule source>.Value) Then
                    .NumberFormat = "dd/mm/yyyy"
                    .Value = CDate(<cellule source>.Value)
                Else
                    .Value = <cellule source>.Value
                End If
      End With

  5. #5
    Membre habitué Avatar de zangaloni
    Profil pro
    Étudiant
    Inscrit en
    Mars 2009
    Messages
    474
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2009
    Messages : 474
    Points : 151
    Points
    151
    Par défaut
    ça marche.
    merci beaucoup

  6. #6
    Membre émérite
    Homme Profil pro
    Inscrit en
    Décembre 2011
    Messages
    1 186
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 1 186
    Points : 2 502
    Points
    2 502
    Par défaut
    Content de voir que ça fonctionne .
    Bonne soirée.

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

Discussions similaires

  1. Inversion mois/jour lors d'une importation d'un CSV
    Par miliev83 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 11/07/2013, 12h20
  2. Réponses: 3
    Dernier message: 07/06/2011, 14h50
  3. Inversion mois/jour lors d'une importation d'un CSV
    Par mamax29 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 11/06/2010, 14h43
  4. PB date lors d'une insertion en Base.
    Par NATHW dans le forum Langage SQL
    Réponses: 4
    Dernier message: 09/09/2004, 17h53
  5. Conversion de date lors d'un import
    Par bilbon.S dans le forum SQL Procédural
    Réponses: 4
    Dernier message: 26/03/2004, 14h33

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