4 réponses
Bonjour,
Tu as fait une petite erreur de syntaxe à la dernière ligne.
En effet, tu fais appel au membre "maplage" depuis ta Worksheet (ws) alors qu'il s'agit d'un membre de la fonction.
La correction à apporter est simplement de retirer ws, comme suit :
Cordialement,
FlawTECH
Tu as fait une petite erreur de syntaxe à la dernière ligne.
En effet, tu fais appel au membre "maplage" depuis ta Worksheet (ws) alors qu'il s'agit d'un membre de la fonction.
La correction à apporter est simplement de retirer ws, comme suit :
maplage.Select
Cordialement,
FlawTECH
Bonjour a tous,
Ce code peut etre dans toute feuille en dehors de "Source"
Pourquoi vous selectionnez cette plage ????
Ce code peut etre dans toute feuille en dehors de "Source"
Sub Bouton1_Cliquer() Dim dernligne As Integer, derncolonne As Integer, ws As Worksheet Dim maplage As Range Set ws = Sheets("Source") With ws 'dernière ligne colonne A dernligne = .Range("A" & Rows.Count).End(xlUp).Row 'dernière colonne ligne 1 derncolonne = .Cells(1, .Cells.Columns.Count).End(xlToLeft).Column Set maplage = .Range(.Cells(1, 1), .Cells(dernligne, derncolonne)) .Activate maplage.Select End With End Sub
Pourquoi vous selectionnez cette plage ????
Bonjour,
Pour selectionner quoi que ce soit dans une feuille, elle doit être active ......
d'ou le
ce que je fait a l'intérieur du with end With
Pour selectionner quoi que ce soit dans une feuille, elle doit être active ......
d'ou le
.Activateet bien sur pour set plage il fallait dans votre code
ws.range
ce que je fait a l'intérieur du with end With
Bonjour,
Ce code fonctionne f894009. Peux-tu m'expliquer pourquoi cela marche alors qu'avec l'autre syntaxe, ne fonctionne pas ?
A vrai dire, en postant ma question, le but était de sélectionner la plage pour ensuite faire un TCD. Mais entre temps, j'ai trouvé une autre alternative. Cependant même si je n'avais plus besoin de ce code, je souhaitais quand même savoir la réponse pour apprendre de mes erreurs!
Un grand merci à vous deux pour votre sagesse et le temps passé à m'aider
Ce code fonctionne f894009. Peux-tu m'expliquer pourquoi cela marche alors qu'avec l'autre syntaxe, ne fonctionne pas ?
A vrai dire, en postant ma question, le but était de sélectionner la plage pour ensuite faire un TCD. Mais entre temps, j'ai trouvé une autre alternative. Cependant même si je n'avais plus besoin de ce code, je souhaitais quand même savoir la réponse pour apprendre de mes erreurs!
Un grand merci à vous deux pour votre sagesse et le temps passé à m'aider
Merci pour ta réponse, l'erreur n'est plus.
Mais maintenant quand je clic sur mon bouton, je sélectionne toute la plage de la feuille où est mon bouton, alors que je souhaite utiliser la sélection "maplage" dans la feuille "Source".
Peux-tu me proposer une solution à mon problème s'il te plait ?
Cordialement
Il te suffirait d'"activer" la feuille avant de sélectionner le range.
Par contre, si ça te sélectionnait un range dans ta feuille active au lieu de te donner l'erreur 1004, c'est que ton code a changé, vérifie bien que tu sélectionnes la feuille "Source" avant.
Pour activer la feuille, il suffit d'ajouter ceci à la fin :
Cordialement,
FlawTECH
Effectivement quand je met ce code cela m'affiche l'erreur 1004. Je ne comprends pas pourquoi le code ne fonctionne pas. J'ai bien vérifié que je sélectionne la feuille "Source" avant.
Cordialement,
J'ai testé à l'instant, peu importe la feuille sélectionnée, je suis redirigé vers "Source" et la selection est correcte.
Je te remets le code corrigé, tu as peut-être fait une erreur sans le vouloir.
Cordialement,
FlawTECH
J'ai repris ton code et cela ne marche toujours pas lorsque je clic sur le bouton. Cela marche uniquement quand je suis dans la feuille "Source" et que je lance le problème via Virtual Basic. Peut-être est ce du à une option qui a été coché par hasard sur Excel/VBA ? C'est vraiment bizarre parce que ton code parait cohérent et clair. Et, à vrai dire avant de faire la démarche d'aller sur un forum pour avoir de l'aide j'avais déjà essayer cette syntaxe.
Cordialement,