Problématique Macro

Aurel -  
Aurel_1207 Messages postés 3 Statut Membre -
Bonjour à tous,

Je suis en train de m'arracher les cheveux avec une maccro et j aurais grandement besoin de votre aide !
Le but de ma macro est assez simple : en fonction du nombre qui figure dans une cellule (cellule fusionnée E47:G47) je veux masquer ou afficher des lignes.
J'aimerais arriver à ça :
=> Si E47:G47 = 0 alors les lignes 48 à 82 sont entierement masquées
Si E47:G47 = 1 alors seules les lignes 56 à 82 sont masquées
Si E47:G47 = 2 alors seules les lignes 65 à 82 sont masquées
Si E47:G47 = 3 alors seules les lignes 74 à 82 sont masquées
Si E47:G47 = 4 toutes les lignes sont affichées.

J ai quand meme essayé et j'ai ecrit ça :
Sub Macro5()
'
' Macro5 Macro
'

'
Range("E47:G47").Select
If ActiveCell.FormulaR1C1 = "0" Then Rows("47:82").Select
Range("B47").Activate
Selection.EntireRow.Hidden = False
Rows("48:82").Select
Range("B48").Activate
Selection.EntireRow.Hidden = True
Range("E47:G47").Select
If ActiveCell.FormulaR1C1 = "1" Then Rows("48:82").Select
Range("B48").Activate
Selection.EntireRow.Hidden = False
Rows("56:82").Select
Range("B56").Activate
Selection.EntireRow.Hidden = True
Range("E47:G47").Select
If ActiveCell.FormulaR1C1 = "2" Then Rows("48:82").Select
Range("B48").Activate
Selection.EntireRow.Hidden = False
Rows("65:82").Select
Range("B65").Activate
Selection.EntireRow.Hidden = True
Range("E47:G47").Select
If ActiveCell.FormulaR1C1 = "3" Then Rows("48:82").Select
Range("B48").Activate
Selection.EntireRow.Hidden = False
Rows("74:82").Select
Range("B74").Activate
Selection.EntireRow.Hidden = True
Range("E47:G47").Select
If ActiveCell.FormulaR1C1 = "4" Then Rows("48:82").Select
Range("B48").Activate
Selection.EntireRow.Hidden = False
End Sub

Le problème est que ma macro fonctionne quand je la crée, mais après j ai un message d'erreur me demandant si je veux debugger...

Et comme, je galère vraiment, j' ai une autre question : quand on travaille sur des fichiers partages, ou doit on enregistrer la macro (Personal Macro Workbook ou dans le classeur en question) - j'ai essayé les deux et des que quelqu un essaie d'executer la macro depuis son poste tout plante...

Je vous remercie grandement par avance pour votre aide!!!

10 réponses

  1. JCB40 Messages postés 3058 Date d'inscription   Statut Membre Dernière intervention   479
     
    Bonjour
    Un exemple en Vba
    https://www.cjoint.com/c/JEwopgcXcsf
    Faire Alt+F11 pour voir le code de la feuille
    Crdlt
    1
  2. michel_m Messages postés 18903 Date d'inscription   Statut Contributeur Dernière intervention   3 320
     
    bonjour

    Dans un module (avec un bouton)


    Sinon on peut aussi utiliser ce code en l"aménageant avec worksheet_change comme la proposer JCB que je sakue
    1
    1. Aurel
       
      Bonjour
      Tout d abord merci beaucoup !!
      J ai essayé avec votre code mais j ai toujours un message d erreur et la ligne :
      Rows(“48:82”).Hidden = False
      Est surlignee quand j essaie de voir d ou vient le problème...

      Je n y comprends plus rien...
      Merci beaucoup pour votre aide
      0
      1. JCB40 Messages postés 3058 Date d'inscription   Statut Membre Dernière intervention   479 > Aurel
         
        Chez moi le code fonctionne bien
        Fais un essai avec le code de michel_m que le salue au passage
        Sinon envoie un exemple de ton fichier
        0
  3. michel_m Messages postés 18903 Date d'inscription   Statut Contributeur Dernière intervention   3 320
     
    Bonjour Aurel, JCB 40

    Désolé je viens de réessayer et ca fonctionne (xl2007)

    Ci joint classeur refait à compléter avec le choix 2 et 3
    https://mon-partage.fr/f/5iZuFvTo/

    Au passage, les cellules fusionnées sont à bannir au maximum
    Utilise l'option alignement/horizontal/centrer sur plusieurs colonnes

    1
    1. Aurel
       
      Bonjour

      Merci beaucoup pour votre aide !!!!
      En fait j ai compris pourquoi ca ne fonctionnait pas chez moi... mon classeur est protégé (oui c'etait une précision assez utile)
      Donc à partir de votre code j ai ajouté les lignes suivantes :
      ActiveSheet.Unprotect Password:="mdp"
      code
      ActiveSheet.Protect "mdp", True, True, True

      => Maintenant ma macro s'execute bien (merci encore) par contre ma feuille ne se reprotège pas ce qui me pose un gros souci (il s'agit d'un fichier partagé comme vous l aurez compris)

      Merci encore par avance
      0
      1. JCB40 Messages postés 3058 Date d'inscription   Statut Membre Dernière intervention   479 > Aurel
         
        Bonjour

        La feuille qui est partagée doit elle être modifiée par plusieurs personnes?
        Si non , tu la protèges en y mettant un MdP que tu seras seul à connaitre
        De toute façon les MdP sur excel ne servent pas à grand chose...
        Cordialement
        0
      2. Aurel > JCB40 Messages postés 3058 Date d'inscription   Statut Membre Dernière intervention  
         
        La feuille doit être modifiée par une seule personne mais est accessible à une quinzaine de personnes (il s agit d un template que d autres personnes vont utiliser).
        Je l ai protégé par mot de passe ; c est ce qui posait problème avec l exécution de la macro.

        Du coup j ai rajouté dans le code la fonction "unprotect" ce qui fonctionne, la macro s’exécute.
        Le problème par contre c est que la fonction "protect" à la fin ne s’exécute pas et par conséquent toutes les formules du fichier peuvent être modifiées.

        Je sais que les mot de passe sur excel ne servent pas à grand chose mais bon c est déjà ça (j ai quand même pensé à mettre un mdp sur le code de la macro pour éviter que tout le monde est accès au mdp du fichier excel...)
        0
      3. JCB40 Messages postés 3058 Date d'inscription   Statut Membre Dernière intervention   479 > Aurel
         
        Ce que tu peux faire:
        Clique Onglet développeur >>>Icone Visual Basic>>>>Outils>>>>Propriété de VBA Project>>> Protection>>>Cocher(vérouiller le projet) >>>Mettre un MdP >>>Confirmer le MdP>>>>cliquer sur Ok
        0
      4. Aurel > JCB40 Messages postés 3058 Date d'inscription   Statut Membre Dernière intervention  
         
        C'est ce que j avais fait, mais ca permet de protéger le code par mot de passe mais pas de reprotéger la feuille après exécution de la macro
        0
  4. Yoyo01000 Messages postés 1720 Date d'inscription   Statut Membre Dernière intervention   168
     
    Bonjour,
    pour plus tard : Si E47 = 0 alors les lignes 48 à 82 sont entierement masquées

    Il faut toujours éviter au maximum la fusion de cellules et dans le cas inverse, il est inutile d'inscrire la plage mais seulement la 1ère cellule (ici E47)
    1
    1. michel_m Messages postés 18903 Date d'inscription   Statut Contributeur Dernière intervention   3 320
       
      Yoyo, bonjour,

      Qu' il y a t'il ne nouveau par rapport à ce que j'ai déjà proposé ???

      j'ai écrit;
      1/
      "les cellules fusionnées sont à bannir au maximum"
      2/
      si E47=0 --> lignes 48:82 masquées --> select case case 0,4

      Pëut-être relire ce qui a été proposé afin d'éviter de passer pour une mouche du coche
      0
      1. Yoyo01000 Messages postés 1720 Date d'inscription   Statut Membre Dernière intervention   168 > michel_m Messages postés 18903 Date d'inscription   Statut Contributeur Dernière intervention  
         
        C'est pas la peine de s'énerver. Je te laisse libre-arbitre de penser, ou pas, que je veux passer pour la mouche du coche. Si mon commentaire précédent t'a paru inutile, la réponse que tu fais à celui-ci ne l'est pas moins non plus alors ;)

        Bonne journée.
        0
  5. Vous n’avez pas trouvé la réponse que vous recherchez ?

    Posez votre question
  6. JCB40 Messages postés 3058 Date d'inscription   Statut Membre Dernière intervention   479
     
    Re bonjour
    Tu colles ce code dans ThisWorkBook en modifiant le nom de la feuil concernée et le MdP
    Mais avant tu fais sauter tous les MdP qu'il y a sur cette feuille .Quand tu voudras faire une modif dans la feuille il te sera demandé le MdP

    Private Sub Workbook_BeforeSave(ByVal SaveAsUI As Boolean, Cancel As Boolean)
    ThisWorkbook.Worksheets("Feuil1").Protect Password:="0000"
    End Sub

    Ci-dessous un exemple MdP 0000
    https://www.cjoint.com/c/JEzqXqEoblf

    Cordialement
    0
  7. JCB40 Messages postés 3058 Date d'inscription   Statut Membre Dernière intervention   479
     
    Bonjour

    plus de nouvelles je suppose que ton problème est résolu...
    0
  8. Aurel
     
    Bonjour
    Je suis désolée je n avais pas vu votre retour.
    Non je n ai toujours pas résolu mon problème.
    Le fait est que je mets mon fichier a disposition de plusieurs personnes qui doivent le modifier / l utiliser (il s agit d un formulaire à remplir) mais je dois bloquer les formules que j ai mises pour éviter que quelqu un les modifie / supprime.

    Donc il faut que j arrive dnas le code de ma macro à "déprotéger" la feuille pour que la macro s exécute puis que de reprotéger la feuille des que la macro est exécutée
    et en mettant :
    ActiveSheet.Unprotect Password:="mdp"
    code
    ActiveSheet.Protect "mdp", True, True, True

    Ma feuille ne se reprotege pas.

    Merci encore par avance
    Meilleures salutations
    0
  9. JCB40 Messages postés 3058 Date d'inscription   Statut Membre Dernière intervention   479
     
    Bonjour
    Peux tu m'envoyer en Mp ton fichier
    Crdlt

    0
    1. JCB40 Messages postés 3058 Date d'inscription   Statut Membre Dernière intervention   479
       
      Envoies ton fichier la solution est trouvée
      crdlt
      0
      1. Aurel_1207 Messages postés 3 Statut Membre > JCB40 Messages postés 3058 Date d'inscription   Statut Membre Dernière intervention  
         
        Je vous remercie grandement mais comment fait on pour envoyer un fichier ?
        cdt
        0
  10. JCB40 Messages postés 3058 Date d'inscription   Statut Membre Dernière intervention   479
     
    Bonjour,
    Un exemple de votre fichier avec explications serait le bienvenu.
    Pour transmettre un fichier,
    Veillez à ce qu'il n'y ait PAS DE DONNEES CONFIDENTIELLES
    il faut passer par un site de pièce jointe tel que cjoint.com

    Allez sur ce site : https://www.cjoint.com/
    Clic sur parcourir,
    Cherche ton fichier,
    clic sur ouvrir,
    Clic sur "Créer le lien cjoint",
    Copier le lien,
    Revenir ici le coller dans une réponse...
    Cordialement

    0
  11. Aurel_1207 Messages postés 3 Statut Membre
     
    voici le lien :
    https://www.cjoint.com/c/JEBpM7XpHTN

    Meilleures salutations
    0
    1. Aurel_1207 Messages postés 3 Statut Membre
       
      Les cellules gris clair sont des formules et je les ai déjà protégées (format de cellule / Protection / Protégées).
      Les cases blanches sont à remplir et sont soit libres soit des listes déroulantes
      Concernant le mot de passe sur la macro je vous l envoie par MP

      Milles mercis
      0