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 :

Problème aver workbooks.open


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Février 2008
    Messages
    67
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 67
    Points : 48
    Points
    48
    Par défaut Problème aver workbooks.open
    Bonjour à tous.

    à partir d'une macro dans un fichier excel, je souhaite ouvrir un fichier texte (csv) dont la structure est la suivante :

    Date;Heure de la mesure;Mesure brute;Mesure corrigée;F0;
    24/11/2017;09:50:00;13,01;;0:0
    24/11/2017;09:50:10;12,89;;0:0
    24/11/2017;09:50:20;12,76;;0:0
    24/11/2017;09:50:30;12,64;;0:0
    24/11/2017;09:50:40;12,53;;0:0

    Donc clairement, un fichier texte avec ";" comme séparateur

    Lorsque je l'ouvre manuellement dans excel (double clic sur le fichier dans l'explorer, ou fichier/ouvrir/...), aucun souci, il s'ouvre correctement, chaque valeur dans sa colonne.

    Lorsque je passe par la macro, ca se corse.

    J'utilise les instructions suivantes :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    fichier = repertoire & ListBox1.Value & ".csv"
     
    Workbooks.Open Filename:=fichier, Format:=4
    (listbox1.value est le nom que j'ai choisi dans une boite de dialogue préalablement ouverte)

    Théoriquement, Format:=4 indique que le séparateur est un point virgule (j'ai également essayé avec le code 6 et Delimiter :=";"). Pourtant excel s'obstine à considérer la virgule comme séparateur et me place les valeurs numériques du tableau dans deux colonnes.

    Quelqu'un pourrait me dire à quel moment je me plante dans cette histoire ?

    Merci d'avance.

  2. #2
    Membre éprouvé
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Septembre 2007
    Messages
    1 896
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Septembre 2007
    Messages : 1 896
    Points : 984
    Points
    984
    Par défaut
    Bonjour,

    Excel va prendre par défaut le séparateur indiqué par défaut soit le point soit la virgule. Il faut donc remplacer le séparateur d'origine par celui que tu souhaites.

    Voir méthode "Replace". Je vais essayer de trouver ce code et je reviens

    Edit : voir cette discussion https://www.developpez.net/forums/d1...ombre-textbox/
    J’entends et j’oublie,
    Je vois et je me souviens,
    Je fais et je comprends.
    Confucius

  3. #3
    Expert éminent sénior 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
    Points : 32 866
    Points
    32 866
    Par défaut
    Citation Envoyé par tasse2the Voir le message
    à partir d'une macro dans un fichier excel, je souhaite ouvrir un fichier texte (csv) [...] clairement, un fichier texte avec ";" comme séparateur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    fichier = repertoire & ListBox1.Value & ".csv"
    Workbooks.Open Filename:=fichier, Format:=4
    N'utilise pas Open mais OpenText qui offre beaucoup plus de possibilités et de flexibilité.
    https://msdn.microsoft.com/fr-fr/vba...t-method-excel
    Regarde bien la liste de tous les paramètres.

    Lorsque je l'ouvre manuellement dans excel (double clic sur le fichier dans l'explorer, ou fichier/ouvrir/...), aucun souci, il s'ouvre correctement, chaque valeur dans sa colonne.
    C'est parce que ton Excel est francophone alors que VBA est indécrottablement anglophone.
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

  4. #4
    Membre émérite
    Inscrit en
    Octobre 2010
    Messages
    1 401
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 1 401
    Points : 2 684
    Points
    2 684
    Par défaut
    Fais aussi un essai avec Local:=True.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set wb = Workbooks.Open(Filename:=ch, local:=True)
    Cordialement

    Docmarti.

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Février 2008
    Messages
    67
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 67
    Points : 48
    Points
    48
    Par défaut
    L'utilisation d'opentext ne change malheureusement rien au problème. Le fichier est chargé exactement de la même faon qu'avec l'instruction open.

    Par contre, l'option Local:=True semble fonctionner correctement... Du moins sur le PC que j'utilise.

    Merci à tous pour vos réponses.

  6. #6
    Expert éminent sénior 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
    Points : 32 866
    Points
    32 866
    Par défaut
    Citation Envoyé par tasse2the Voir le message
    L'utilisation d'opentext ne change malheureusement rien au problème. Le fichier est chargé exactement de la même faon qu'avec l'instruction open.
    Ca dépend quels paramètres tu utilises.
    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion.

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

Discussions similaires

  1. [XL-2010] Problème ouverture fichier excel via workbooks.open
    Par evranger dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 22/05/2017, 09h03
  2. [XL-2013] Problème avec workbooks.open
    Par eric062 dans le forum Excel
    Réponses: 2
    Dernier message: 18/06/2014, 14h16
  3. [XL-2003] Problème Workbooks.open help
    Par Methodrone8 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 24/04/2013, 15h41
  4. Problème avec Workbooks.Open
    Par kolchang dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 19/07/2010, 11h30
  5. Ouverture CSV par Workbooks.open
    Par PoPmiSiR dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 14/10/2005, 10h19

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