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 - Conversion xls / csv : point virgule


Sujet :

Macros et VBA Excel

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    306
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 306
    Points : 164
    Points
    164
    Par défaut vba - Conversion xls / csv : point virgule
    Bonjour,

    Beaucoup de posts parlent du problème de conversion d'un xls vers csv avec comme délimiteur le point virgule.

    Certains disent que le "secret" est d'ajouter Local:=True au moment de la conversion afin de récupérer les options régionales :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    wbk.SaveAs Filename:="C:\monfichier.csv", FileFormat:=xlCSV, CreateBackup:=False, Local:=True
    Cela ne fonctionne pas alors même que mon délimiteur de champs par défaut est bien le point virgule.

    D'autres proposent des solution abracadabrantesques...

    Quelqu'un a-t-il une solution simple et propre qui fonctionne ?

    Merci mille fois.

  2. #2
    Expert éminent
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Points : 7 964
    Points
    7 964
    Par défaut
    Bonjour,

    Il faut essayer de prendre l'habitude d'afficher le code complet et pas seulement des petits morceaux, le problème ne vient pas toujours de là où l'on pense.

    Le code ci-dessous transforme bien mon classeur excel en fichier csv et lorsque tu ouvres ce fichier csv avec le bloc note, le séparateur est bien le ;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Sub Export_CSV()
    Dim NomFichier As String
     
    NomFichier = "test_exportation_csv.csv"
    ActiveWorkbook.SaveAs Filename:=ThisWorkbook.Path & "\" & NomFichier, FileFormat:=xlCSV
     
    End Sub
    En espérant que cela puisse t'aider

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    306
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 306
    Points : 164
    Points
    164
    Par défaut
    Bonjour,

    Je n'ai mis qu'un bout car le reste est simplissime :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Sub test()
     
    Dim wbk As Workbook
    Set wbk = Workbooks.Open("C:\Test1.xls")
    wbk.SaveAs Filename:="C:\Test1.csv", FileFormat:=xlCSV, CreateBackup:=False, Local:=True
    wbk.Close savechanges:=True
     
    End Sub
    Visiblement il y a un autre paramètre (en dehors du code et des paramètres régionaux) qui rentre ne compte.

    Merci.

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    306
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 306
    Points : 164
    Points
    164
    Par défaut
    Bonjour,

    Alors e fait, le coupable est :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    wbk.Close savechanges:=True
    Si je le remplace par :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    wbk.Close savechanges:=False
    Ca marche.

    Merci beaucoup.

  5. #5
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 546
    Points
    15 546
    Par défaut
    Je viens de voir ta réponse : Le pb n'est pas là ! Tu l'as réglé ainsi, c'est bien mais si tu modifies le classeur et que tu as à faire la même chose, la solution passe par DoEvents
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Dim wbk As Workbook
    Set wbk = Workbooks.Open("C:\Test1.xls")
    DoEvents
    wbk.SaveAs Filename:="C:\Test1.csv", FileFormat:=xlCSV, CreateBackup:=False, Local:=True
    Doevents
    wbk.Close savechanges:=True
    Un coup d'oeil dans l'aide te donnera une explication. Toute manipulation de fichier (ouverture, fermeture, sauvegarde...) sollicite le système et DoEvents est là pour lui donner le temps de faire ses petites affaires
    A toute fin utile... ou inutile

  6. #6
    Futur Membre du Club
    Inscrit en
    Juillet 2007
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 5
    Points : 7
    Points
    7
    Par défaut
    Chez moi, les DoEvents n'ont rien changé, mais la solution est bien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    wbk.Close savechanges:=False
    En effet, lors du SaveAs, le paramètre Local:= True va permettre d'utiliser le séparateur des regional settings.

    Mais si juste après ça, on réenregistre avec savechanges:=True, l'enregistrement se fera avec la valeur Local par défaut, soit False, et le séparateur sera donc la virgule.
    CQFD

    Merci à tous

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

Discussions similaires

  1. [AC-2010] Import personnalisé csv point-virgule et guillemet
    Par marsouin_89 dans le forum VBA Access
    Réponses: 3
    Dernier message: 22/03/2014, 17h10
  2. [XL-2007] Exporter csv point virgule
    Par wamkey dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 19/01/2014, 20h41
  3. Format Conversion XLS ==> CSV
    Par chlolo5 dans le forum Excel
    Réponses: 1
    Dernier message: 18/03/2013, 19h40
  4. Conversion XLS CSV : probleme virgule
    Par B&B dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 07/05/2008, 16h55
  5. Conversion xls / csv
    Par ktsys dans le forum C++
    Réponses: 3
    Dernier message: 18/04/2007, 15h27

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