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 :

Excel redémarre lors d'une sauvegarde


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    apt
    apt est déconnecté
    Membre éclairé
    Inscrit en
    Mai 2002
    Messages
    867
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 867
    Par défaut Excel redémarre lors d'une sauvegarde
    Bonjour à tous,

    Dans un fichier, lorsque je voudrais sauvegarder des modifications, Excel signal une erreur et redémarre.

    Microsoft Office Excel à rencontré un problème et doit fermé. Nous vous prions de nous excuser pour le désagrément encouru.
    Comment résoudre ce problème ?

    Merci d'avance.

  2. #2
    Membre expérimenté Avatar de L'Albatros
    Homme Profil pro
    Chercheur en économie - statistique
    Inscrit en
    Avril 2012
    Messages
    150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur en économie - statistique
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2012
    Messages : 150
    Par défaut
    Oulah...
    Avez-vous intégré des macros dans ce classeur ?

  3. #3
    apt
    apt est déconnecté
    Membre éclairé
    Inscrit en
    Mai 2002
    Messages
    867
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 867
    Par défaut
    Bonjour Albatros,

    Ce fichier contient plusieurs macros et il marchait parfaitement ca fait deux ans.

    Seulement récemment j'ai ajouté un petit code pour renommer automatiquement des plages en plus d'un code pour calculer la moyenne avec mise en forme conditionnelle.

    Mais je ne sais pas si mon problème vient de ces deux morceaux de code ?

  4. #4
    Membre expérimenté Avatar de L'Albatros
    Homme Profil pro
    Chercheur en économie - statistique
    Inscrit en
    Avril 2012
    Messages
    150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur en économie - statistique
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2012
    Messages : 150
    Par défaut
    Ah ben il y a des chances, oui...

    Pourriez-vous svp poster ce rajout de code ?

  5. #5
    apt
    apt est déconnecté
    Membre éclairé
    Inscrit en
    Mai 2002
    Messages
    867
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 867
    Par défaut
    Bonjour Albatros,

    Voila :

    1 - Calcul de la moyenne avec MFC :

    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
    If x.Row <> [Z1] Then
                pCel = [Z1].Value    '
                MsgBox "Nouvelle ligne trouvée " & x.Row & " pour l'article : " & c.Value & vbCrLf & _
                       "Ancienne ligne Z1 : " & [Z1] & vbCrLf & _
                       "Nbre de valeurs dans la ligne précédente " & [Z1].Value & " est " & Application.CountA(Range("N" & [Z1].Value & ":X" & [Z1].Value))
                If Application.WorksheetFunction.CountA(Range("N" & pCel & ":X" & pCel)) > 1 Then
                    MsgBox "Ligne en traitement previous cell : " & pCel
                    Worksheets("Feuil2").Range("N" & pCel & ":X" & pCel).Name = "Prix"
                    Cells(pCel, 25).Activate
     
                    With ActiveCell
                        .Formula = "=AVERAGE(" & Range("Prix").Address(0, 0) & ")"
                        .ClearComments    'je supprime le commentaire existant
                        .AddComment    'je créé le commentaire
                        .Comment.Visible = True
                        .Comment.Text Text:=Range("M" & pCel).Text     'commentaire
                        .Comment.Shape.ScaleWidth 1.1, msoFalse, msoScaleFromTopLeft
                        .Comment.Shape.ScaleHeight 0.19, msoFalse, msoScaleFromTopLeft
                    End With
                Else
                    Cells(pCel, 25).ClearComments
                End If
                [Z1].Value = x.Row
            End If
    2 - Plages nommées dynamiquement :

    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
    '-------------------------------------
        dbTab = Array("Débit", "Débit_Date", "Débit_Noms", "reDébit", "reDébit_Date", "reDébit_Noms")
        Set myPlg = Union([A2:C2], [I2:k2])
        x = 0
        For Each c In myPlg.Cells
            If Len(c.Offset(1, 0)) > 0 Then
                Range(c.Address, c.End(xlDown).Address).Name = dbTab(x)
            Else
                c.Name = dbTab(x)
            End If
     
            x = x + 1
        Next
        Set myPlg = Nothing
        '--------------------------------------------

  6. #6
    Membre expérimenté Avatar de L'Albatros
    Homme Profil pro
    Chercheur en économie - statistique
    Inscrit en
    Avril 2012
    Messages
    150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur en économie - statistique
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2012
    Messages : 150
    Par défaut
    Tac, à la volée: erreur de syntaxe pour la boucle For Each c...Next c
    Il faut mettre quelque chose après Next, sinon, boucle infinie (si ça passe entre les mailles du debugger)
    cf ci-dessous:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    For Each c In myPlg.Cells
            If Len(c.Offset(1, 0)) > 0 Then
                Range(c.Address, c.End(xlDown).Address).Name = dbTab(x)
            Else
                c.Name = dbTab(x)
            End If
     
            x = x + 1
        Next c
    Il y a peut-être d'autres trucs, mais essaie déjà comme cela

Discussions similaires

  1. Espace requis lors d'une sauvegarde complète MOSS
    Par gracouille dans le forum SharePoint
    Réponses: 2
    Dernier message: 04/07/2008, 11h20
  2. Fermeture du Userform lors d'une sauvegarde
    Par wabo67 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 22/12/2007, 19h12
  3. {VBA Excel}Erreur lors d'une copie
    Par Thomas69 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 14/08/2007, 10h57
  4. Petit probleme avec les Border lors d'une sauvegarde
    Par Mike888 dans le forum Interfaces Graphiques en Java
    Réponses: 7
    Dernier message: 06/06/2006, 10h33
  5. Réponses: 7
    Dernier message: 27/01/2006, 16h42

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