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

VBA Access Discussion :

Créer fichier Excel protégé en lecture seule [AC-2010]


Sujet :

VBA Access

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Février 2008
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Belgique

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2008
    Messages : 32
    Points : 33
    Points
    33
    Par défaut Créer fichier Excel protégé en lecture seule
    Bonjour,

    J'ai une procédure vba qui exporte les données d'une de mes requête access en fichier excel. Cependant pour palier à un mauvais usage des utilisateurs du fichier Excel, j'ai besoin de protéger ce fichier Excel (lecture seule avec mot de passe ou pas).

    Voici mon code de création de mon fichier Excel

    '2. génération fichiers Excel
    Dim qd As QueryDef
    mag = Forms![Traitement retour global].[NumMagasin].Value
    'MsgBox mag
    jour = Format(Now, "dd-mm-yyyy hh_mm")
    NomFichier = ("P:\RetourVpm\Export SAP\") & mag & (" Retour stock du ") & jour & (".xls")
    'MsgBox NomFichier
    DoCmd.TransferSpreadsheet acExport, acSpreadsheetTypeExcel97, "R_ExcelStock", NomFichier

    NomFichier2 = ("P:\RetourVpm\Export SAP\") & mag & (" Destruction du ") & jour & (".xls")
    DoCmd.TransferSpreadsheet acExport, acSpreadsheetTypeExcel97, "R_ExcelDestruction", NomFichier2

    DoCmd.RunMacro "ValidFlag"

    DoCmd.RunMacro "MacroFermeture"
    Si quelqu'un pouvais me dire ce qu'il faut ajouter pour rendre ce fichier en lecture seule, se serait le top.

    Merci d'avance

  2. #2
    Membre éprouvé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2010
    Messages
    801
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Seine Maritime (Haute Normandie)

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

    Informations forums :
    Inscription : Février 2010
    Messages : 801
    Points : 1 107
    Points
    1 107
    Par défaut
    Bonjour,

    Rajoutes ce code à la suite de ta fonction :
    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
        ' ===== Déclaration des variables =====
        Dim XLApp As Excel.Application
        Dim XLBook As Excel.Workbook
        Dim feuille As Excel.Worksheet
     
        ' ===== Ouverture du classeur Excel en mode invisible =====
        Set XLApp = CreateObject("Excel.Application")
        XLApp.Visible = False
        Set XLBook = XLApp.Workbooks.Open(NomFichier)
     
        ' ===== Pour chaque feuille du classeur, on verrouille les cellules =====
        For Each feuille In XLBook.Sheets
            feuille.Protect DrawingObjects:=True, Contents:=True, Scenarios:=True
        Next feuille
     
        ' ===== Sauvegarde du fichier =====
        XLBook.Save
     
        ' ===== Fermeture d'Excel =====
        XLApp.Quit
     
        ' ===== Libération des variables =====
        Set feuille = Nothing
        Set XLBook = Nothing
        Set XLApp = Nothing
    ça devrait le faire

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Février 2008
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Belgique

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2008
    Messages : 32
    Points : 33
    Points
    33
    Par défaut
    Merci je viens d'essayer et sur la ligne
    => Dim XLApp As Excel.Application

    j'ai l'erreur :" type défini par l'utilisateur non défini"...

    j'ai du louper qqchose

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Février 2008
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Belgique

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2008
    Messages : 32
    Points : 33
    Points
    33
    Par défaut
    j'ai trouvé, il fallait que j'active la bibliothèque... par contre ya autre chose qui marche pas faut que j'analyse...

    Merci de ta réponse, cela fait un peu avancer le schmilblick

  5. #5
    Membre éprouvé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2010
    Messages
    801
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Seine Maritime (Haute Normandie)

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

    Informations forums :
    Inscription : Février 2010
    Messages : 801
    Points : 1 107
    Points
    1 107
    Par défaut
    Oui désolé j'ai oublié de préciser pour la bibliothèque :p Sinon j'avais oublié un bout de code. Je l'ai mis à jour. Dis-moi si c'est mieux comme ça

  6. #6
    Nouveau membre du Club
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Février 2008
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Belgique

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2008
    Messages : 32
    Points : 33
    Points
    33
    Par défaut
    Cette solution, marche tip top... merci à toi !

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

Discussions similaires

  1. [XL-2010] enregistrement automatique d'un fichier Excel ouvert en lecture seule
    Par hakoko dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 05/08/2013, 17h17
  2. [AC-2007] table liée sur fichier Excel protégé en lecture
    Par tibofo dans le forum Modélisation
    Réponses: 3
    Dernier message: 05/08/2010, 12h54
  3. le Code pr un fichier Excel en mode lecture seule
    Par wise_mind dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 17/08/2008, 14h22
  4. Réponses: 6
    Dernier message: 11/12/2007, 10h42
  5. Lecture d'un fichier Excel uniquement sur un seul poste
    Par loutsky dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 24/05/2006, 08h09

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