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 :

Modifications en csv ne s'enregistrent pas ! [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Territoire de Belfort (Franche Comté)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2015
    Messages : 2
    Par défaut Modifications en csv ne s'enregistrent pas !
    Bonjour à tous,

    ça doit faire 2 jours que je cherche et je ne trouve aucun topic avec mon problème alors je me decide à ouvrir le mien.

    Ce que je veux faire: ouvrir un fichier en .csv le modifier et le réenregister en .csv. Du coup j'utilise l'instruction save as avec les paramètres nécessaires(j'ai déjà essayer conflict resolution mais ça n'a rien changé) j'accepte de remplacer l'autre fichier etc... La macro s'effectue correctement.
    Pourtant quand j'ouvre le fichier csv par la suite il n'a pas enregistré mes modifications. Je précise que lorsque j'enregistre ce fichier dans un autre fichier je n'ai pas de problème. Je pense que je peux toujours bidouillé mais honnêtement je ne comprends pas pourquoi ça ne fonctionne pas.
    Merci d'avance de votre aide !

    Je mets l'ensemble de la partie concernée mais l'enregistrement se trouve à la fin

    Code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
     Dim fldr As FileDialog
        Dim GetFolder, sItem, Toolname As String
        Dim Recipenumber, Line As Integer
     
        MsgBox ("Select the Folder containing the Machine's documents")
        Set fldr = Application.FileDialog(msoFileDialogFolderPicker)
        With fldr
            .Title = "Select the Folder"
            .AllowMultiSelect = False
            If .Show <> -1 Then GoTo NextCode
            sItem = .SelectedItems(1)
        End With
    NextCode:
        GetFolder = sItem
        Set fldr = Nothing
     
        If SourceFile.Sheets(3).Range("F17") = "Left" Then
            Set TargetFileMop = Application.Workbooks.Open(GetFolder & "\PROJECTS\VCELL_NG_2015_06_01\DATA\RECIPE\MOP_ST1.CSV", Local:=True)
        Else
            Set TargetFileMop = Application.Workbooks.Open(GetFolder & "\PROJECTS\VCELL_NG_2015_06_01\DATA\RECIPE\MOP_ST2.CSV", Local:=True)
        End If
    RecipeChoice:
        Recipenumber = InputBox("Choose the recipe number", , 1)
        Line = 6 + Recipenumber
        Toolname = TargetFileMop.Sheets(1).Range("H" & Line).Value
        If Toolname <> Recipenumber Then
            If MsgBox("Recipe of the tool" & Toolname & "is already there and will be lost Do you want to continue?", vbYesNo) = vbNo Then
                GoTo RecipeChoice
            End If
        End If
     
        'Condition poutre gauche ou droite (pas le même nom de fichier)
        If SourceFile.Sheets(3).Range("F17") = "Left" Then
            SourceFile.Sheets("MOP_ST1").Range("E7:DH7").Copy
        Else
            SourceFile.Sheets("MOP_ST2").Range("E7:DH7").Copy
        End If
        TargetFileMop.Sheets(1).Range("E" & Line & ":DH" & Line).PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
            :=False, Transpose:=False
        Application.CutCopyMode = False
     
        'Enregistrement du nouveau fichier
        TargetFileMop.SaveAs Filename:=TargetFileMop.Name, FileFormat:=xlCSV, CreateBackup:=False, Local:=True
        TargetFileMop.Close SaveChanges:=False
     
     
     
        'Condition poutre gauche ou droite (pas le même nom de fichier)
        If SourceFile.Sheets(3).Range("F17") = "Left" Then
            Set TargetFileRecette = Application.Workbooks.Open(GetFolder & "\PROJECTS\VCELL_NG_2015_06_01\DATA\RECIPE\GROUPE_RECETTE_ST1.CSV", Local:=True)
            SourceFile.Sheets("GROUPE_RECETTE_ST1").Range("D7:S7").Copy
        Else
     
            Set TargetFileRecette = Application.Workbooks.Open(GetFolder & "\PROJECTS\VCELL_NG_2015_06_01\DATA\RECIPE\GROUPE_RECETTE_ST2.CSV", Local:=True)
            SourceFile.Sheets("GROUPE_RECETTE_ST2").Range("D7:S7").Copy
     
        End If
     
        TargetFileRecette.Sheets(1).Range("D" & Line & ":S" & Line).PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
            :=False, Transpose:=False
        Application.CutCopyMode = False
        TargetFileRecette.Sheets(1).Range("E" & Line) = Recipenumber
        TargetFileRecette.Sheets(1).Range("F" & Line) = Recipenumber
     
        'Enregistrement du nouveau fichier
        TargetFileRecette.SaveAs Filename:=TargetFileRecette.Name, FileFormat:=xlCSV, CreateBackup:=False, Local:=True
        TargetFileRecette.Close SaveChanges:=False

  2. #2
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

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

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Bonjour,

    Je pense que ton fichier doit se sauvegarder dans un autre répertoire puisque tu ne définit pas celui-ci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TargetFileMop.SaveAs Filename:=TargetFileMop.Name, FileFormat:=xlCSV, CreateBackup:=False, Local:=True
    Essaie en lui ajoutant le chemin ou en utilisant FullName
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TargetFileMop.SaveAs Filename:=TargetFileMop.FullName, FileFormat:=xlCSV, CreateBackup:=False, Local:=True

  3. #3
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Territoire de Belfort (Franche Comté)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2015
    Messages : 2
    Par défaut
    Effectivement ça marche !
    Merci beaucoup!

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

Discussions similaires

  1. TDBGrid: Les modifications ne s'enregistrent pas dans la base
    Par billbocquet dans le forum Bases de données
    Réponses: 11
    Dernier message: 13/10/2011, 10h50
  2. Réponses: 6
    Dernier message: 31/01/2006, 16h55
  3. [CSV] Redirection ne fonctionne pas
    Par Brizzio dans le forum Langage
    Réponses: 12
    Dernier message: 16/12/2005, 10h55
  4. db enregistre pas toujour
    Par cre3000 dans le forum Bases de données
    Réponses: 1
    Dernier message: 23/05/2005, 12h16
  5. Modification simultanée d'un même enregistrement
    Par Arnaud57 dans le forum Administration
    Réponses: 5
    Dernier message: 05/08/2004, 12h31

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