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

Excel Discussion :

Fichier excel ne s'ouvre pas a cause vba


Sujet :

Excel

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2011
    Messages : 48
    Points : 23
    Points
    23
    Par défaut Fichier excel ne s'ouvre pas a cause vba
    Bonjour,

    Dans une ancienne discussion (statut: RÉSOLU) J'ai copié un code et l'adapter a mon cas. C'est pour empêcher l'ouverture du fichier si on le renomme. Le code ne fonctionne pas exactement comme je l'aurai souhaité. Même si je le renomme avec son vrai nom contenu dans le code il continue quand même a m'afficher le même message: “Vous n’êtes pas autorisés à renommer ce fichier. Merci!”. Et lorsque je clique sur OK le fichier se ferme.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    Private Sub Workbook_Open()
    MsgBox “Vous n’êtes pas autorisés à renommer ce fichier.  Merci!”
    nom = ActiveWorkbook.Name
    nomorigin = "EXEMPLE.xlsm"
    If nom <> nom1 Then
    ActiveWorkbook.Close
    End If
    End Sub
    Quelqu'un peut-il se pencher sur mon cas pour voir d'ou provient mon erreur.

    Merci infiniment d'avance.

  2. #2
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 944
    Points : 28 943
    Points
    28 943
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Même si je le renomme avec son vrai nom contenu dans le code il continue quand même a m'afficher le même message: “Vous n’êtes pas autorisés à renommer ce fichier. Merci!”. Et lorsque je clique sur OK le fichier se ferme.
    Une procédure se déroulant d'une façon séquentielle et ta première ligne est l'affichage du fameux message. Alors comment veux-tu qu'il en soit autrement ?
    Ensuite, tu compares la variable Nom avec Nom1 or tu utilises Nom et nomorigin et de plus si la casse n'est pas correcte et/ou des caractères espacés se trouvent avant ou après le nom, le résultat de la condition sera fausse.
    Pour éviter ce type de désagrément il faut utiliser les fonctions Trim et Lcase ou Ucase
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Private Sub Workbook_Open()
     Dim nom As String, nomorigin As String
     nom = ActiveWorkbook.Name
     nomorigin = "EXEMPLE.xlsm"
     If Trim(LCase(nomorigin)) <> Trim(LCase(nom)) Then
      ActiveWorkbook.Close
     End If
    End Sub
    Et je placerais la fonction MsgBox à l'intérieur de la procédure conditionnelle

    ps: Je te conseille l'utilisation de Option Explicit placé en début de procédure pour t'obliger à déclarer tes variables.

  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
    Pris à ton propre piège.

    Commence par refuser de valider les macro (pour que cette macro ne s'enclenche pas).
    Ensuite, tu mets ta ligne ActiveWorkbook.Close en commentaire. Histoire de pouvoir faire des texts en toute quiétude.

    Juste après ton nom=... mets une ligne :
    Histoire de voir ce que contient effectivement ta variable.

    A mon avis, c'est soit une histoire de majuscules/minuscules, soit une histoire d'extension qui ne s'affiche pas parce que dans l'Exploreur Windows tu as laissé cochée l'option Masquer les extensions.

  4. #4
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2011
    Messages : 48
    Points : 23
    Points
    23
    Par défaut Wow
    Wowww elle est pas belle la vie? Comme çà été rapide et efficace a la fois. Je suis un homme heureux. Merci infiniment Philippe pour votre code. Il fait mon bonheur. Vous me dites de placer le MsgBox dans la processus. C'est après le If? Je suis novice en programmation.

    Par ailleurs je voudrais savoir a quoi çà sert Trim et LCase.

    Merci Menhir. Vous avez raison je me suis piégé moi même mais heureusement j'avais fais une copie du fichier. Sinon c'aurait été près d'un mois de travail parti en fumée

    Merci beaucoup

  5. #5
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 944
    Points : 28 943
    Points
    28 943
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Par ailleurs je voudrais savoir a quoi çà sert Trim et LCase.
    Le meilleur ami du programmeur pour obtenir de l'aide, c'est la touche de fonction F1.
    Il suffit de placer le pointeur de la souris du la fonction, méthode ou propriété dont on veut avoir des informations et cliquer sur cette touche. Par défaut l'aide se fait sur Net mais bien souvent c'est le néant. Il suffit de cliquer en bas à droite de la boîte de dialogue et modifier la recherche en choisissant de faire la recherche sur son propre PC.
    Extrait de l'aide (F1)
    LTrim, RTrim; Trim : Renvoie une valeur de type Variant (String) contenant une copie d'une chaîne en supprimant les espaces de gauche (LTrim), les espaces de droite (RTrim) ou les deux (Trim).
    LCase : Renvoie une valeur de type String convertie en minuscules.
    Exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     Debug.Print Trim(LCase(" JE cherche de l'aide sur DeVELoppez.Com  "))
    Renvoie "je cherche de l'aide sur developpez.com"

  6. #6
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2011
    Messages : 48
    Points : 23
    Points
    23
    Par défaut Merci Philippe
    Merci infiniment Philippe pour votre aide précieuse. Pour vos conseils je prends note et j'en ferai bon usage dans le future

    Le fameux message d'avertissement je l'ai placé dans la procédure If comme suggéré et çà marche nickel.

    Mon problème est résolu

  7. #7
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 944
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 944
    Points : 28 943
    Points
    28 943
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Mon problème est résolu
    Formidable et merci pour ton retour

  8. #8
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Octobre 2013
    Messages
    385
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2013
    Messages : 385
    Points : 661
    Points
    661
    Par défaut
    Bonjour à tous,

    Je viens juste pour rajouter un petit truc.

    Il faut savoir qu'il est possible d'ouvrir un fichier Excel sans exécuter le code vba du fichier en question. Il suffit pour cela de maintenir la touche SHIFT enfoncée en ouvrant le classeur.

    Un petit truc tout bête qui permet parfois de ne pas avoir à se retaper tout le travail

  9. #9
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2011
    Messages : 48
    Points : 23
    Points
    23
    Par défaut Merci
    Salut mat955,
    Je viens d'essayer l'astuce proposé et çà marche. Merci beaucoup

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

Discussions similaires

  1. [XL-2007] Fichier exel ne s'ouvre pas feuille dans vb6
    Par franc83 dans le forum Excel
    Réponses: 1
    Dernier message: 24/07/2013, 21h50
  2. Fichier qui ne s'ouvre pas
    Par BelDe dans le forum Mac OS X
    Réponses: 5
    Dernier message: 13/04/2012, 21h32
  3. [Access 2007] Fichier excel qui ne s'ouvre pas
    Par enkie dans le forum VBA Access
    Réponses: 5
    Dernier message: 07/08/2008, 10h08
  4. fichier excel ne s`ouvre plus?????
    Par redabadache3 dans le forum Excel
    Réponses: 2
    Dernier message: 24/12/2005, 10h59
  5. [C#] [Excel] Feuille qui s'ouvre pas...
    Par lololefada dans le forum Windows Forms
    Réponses: 7
    Dernier message: 15/07/2004, 14h45

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