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 :

[VBA-E] Formatage des données à l'ouverture d'un fichier texte


Sujet :

Macros et VBA Excel

  1. #1
    Candidat au Club
    Inscrit en
    Novembre 2005
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 3
    Points : 2
    Points
    2
    Par défaut [VBA-E] Formatage des données à l'ouverture d'un fichier texte
    Lors de l’ouverture d'un fichier texte les dates sous la forme 01/10/02 à 11/12/02 sont converties en 12/01/02 à 12/11/02. Ce problème ne se pose pas sur les dates de 12/12/02 à 31/12/02.

    Voilà le code utilisé pour l'ouverture du fichier texte :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
        AdresseFichier = Application.GetOpenFilename("Text Files (*.txt)_
                             ,*.txt", , "Choisir le fichier à récupérer")
        If F = "Faux" Then End
        Workbooks.OpenText Filename:=AdresseFichier, _
            Origin:=932, StartRow:=1, DataType:=xlDelimited, TextQualifier:= _
            xlDoubleQuote, ConsecutiveDelimiter:=False, Tab:=True, _
            Semicolon:=False, _
            Comma:=False, Space:=False, Other:=False, FieldInfo:=_
            Array(Array(1, 1), _
            Array(2, 1), Array(3, 1), Array(4, 1), Array(5, 1)),_       
            TrailingMinusNumbers:=True

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    53
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 53
    Points : 59
    Points
    59
    Par défaut date
    la gestion des dates .....
    c récurent
    souvenons-nous du soit disant bug de l'an 2000 ...

    bon, par expérience et qq migrations de logiciel de développement
    j'ai décidé de gérer moi-même mes dates, bon, cela m'a couté l'écriture de deux procédures, l'une de mise en forme, l'autre me dir les jours de semaine, d'année, et même la gestion des jours fériés, y compris paques
    les dates sont stockés en mode texte format aaaammjj
    et fini les pb
    si intéressé par les procédures, tu dis

  3. #3
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut Re: Formatage des données à l'ouverture d'un fichier texte
    Citation Envoyé par jmercier
    Lors de l’ouverture d'un fichier texte les dates sous la forme 01/10/02 à 11/12/02 sont converties en 12/01/02 à 12/11/02. Ce problème ne se pose pas sur les dates de 12/12/02 à 31/12/02.

    Voilà le code utilisé pour l'ouverture du fichier texte :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
        AdresseFichier = Application.GetOpenFilename("Text Files (*.txt)_
                             ,*.txt", , "Choisir le fichier à récupérer")
        If F = "Faux" Then End
        Workbooks.OpenText Filename:=AdresseFichier, _
            Origin:=932, StartRow:=1, DataType:=xlDelimited, TextQualifier:= _
            xlDoubleQuote, ConsecutiveDelimiter:=False, Tab:=True, _
            Semicolon:=False, _
            Comma:=False, Space:=False, Other:=False, FieldInfo:=_
            Array(Array(1, 1), _
            Array(2, 1), Array(3, 1), Array(4, 1), Array(5, 1)),_       
            TrailingMinusNumbers:=True
    dans qu'elle colonne as tu tes dates ?
    pour l'info field Info .. essai de remplacer le "1" (format standard) , pour "4" format date "JMA".. sachant que chaque Array.. représente une colonne avec 1° élément le numérpo de colonne est en 2° le type de format , par exemple si les dates sont dans colonne 2.:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
            Comma:=False, Space:=False, Other:=False, FieldInfo:=_
            Array(Array(1, 1), _
            Array(2, 4), Array(3, 1), Array(4, 1), Array(5, 1)),_
    Bon je suis pas sur que ça marche avec toutes les version d'excel.. mais sur ma version Excel 2000.. c'est ok... [/code]

  4. #4
    Candidat au Club
    Inscrit en
    Novembre 2005
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    les dates sont dans la colonne 1.

    Merci pour les infos

  5. #5
    Candidat au Club
    Inscrit en
    Novembre 2005
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    Merci pour l'info field Info .. J'ai résolu mon problème en remplacant le "1" (format standard) par "4" format date "JMA"..

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 22/09/2009, 17h51
  2. Réponses: 4
    Dernier message: 11/09/2006, 13h47
  3. [VBA] Ajouter, modifier des données ou lecture seul
    Par Virgile59 dans le forum Access
    Réponses: 8
    Dernier message: 20/01/2006, 10h07
  4. [EXCEL] Formatage des données
    Par Cupidon dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 02/11/2005, 21h32
  5. [Struts] Formatage des données
    Par Biloo dans le forum Struts 1
    Réponses: 6
    Dernier message: 15/09/2005, 12h13

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