Précédent   Forum des professionnels en informatique > Logiciels > Microsoft Office > Excel > Macros et VBA Excel
Macros et VBA Excel Vos questions relatives aux macros Excel, à l'utilisation de VBA et à l'automatisation de vos classeurs Excel.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 13/10/2011, 15h24   #1
Membre du Club
 
Inscription : mars 2005
Messages : 181
Détails du profil
Informations personnelles :
Âge : 39
Localisation : France, Paris (Île de France)

Informations forums :
Inscription : mars 2005
Messages : 181
Points : 45
Points : 45
Par défaut Aide sur UserForm

Bonjour

Je fais appel à un Userform via macro
Code :
1
2
3
Sub Replace_MCL()
Replace_MCL_Tool.Show
End Sub
Dans ce userform, j'ai les fonctions suivantes
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
Private Sub Valider_Click()
Dim OldStr As String, NewStr As String
Dim Sh As Worksheet
Dim c As Range
 
OldStr = Replace_MCL_Tool.TextBox1.Value
NewStr = Replace_MCL_Tool.TextBox2.Value
 
Application.ScreenUpdating = False
For Each Sh In ThisWorkbook.Worksheets
    On Error Resume Next
    For Each c In Sh.UsedRange.SpecialCells(xlCellTypeFormulas)
        c.Formula = Replace(c.Formula, OldStr, NewStr)
    Next c
    On Error GoTo 0
Next Sh
End Sub
Private Sub Annuler_Click()
Hide
End Sub
Mais rien ne se passe quand je clique sur Valider (le nom du CommandButton est bien Valider).

Pourriez-vous m'aider ?


Merci
lafafmentvotre est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/10/2011, 17h21   #2
Membre Expert
 
Avatar de aalex_38
 
Inscription : septembre 2007
Messages : 1 596
Détails du profil
Informations forums :
Inscription : septembre 2007
Messages : 1 596
Points : 1 748
Points : 1 748
Bonjour,


Utilise le debogueur et les points d'arret pour voir ou tu passes.
__________________
aalex_38 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/10/2011, 11h07   #3
Membre du Club
 
Inscription : mars 2005
Messages : 181
Détails du profil
Informations personnelles :
Âge : 39
Localisation : France, Paris (Île de France)

Informations forums :
Inscription : mars 2005
Messages : 181
Points : 45
Points : 45
Hello

Je ne connais pas trop donc pas évident pour moi.

Bonjour

Pourriez-vous m'aider ou me guider pour faire tourner mon userform car je suis bloqué.

Merci par avance
lafafmentvotre est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/10/2011, 12h22   #4
Membre Expert
 
Homme
Retraité
Inscription : avril 2011
Messages : 692
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Activité : Retraité

Informations forums :
Inscription : avril 2011
Messages : 692
Points : 1 443
Points : 1 443
Bonjour,

J'ai inséré quelques messages dans ton code.
Cela peut t'aider à découvrir ce qui cloche

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
Private Sub Valider_Click()
Dim OldStr As String, NewStr As String
Dim Sh As Worksheet
Dim c As Range
MsgBox "La commande VALIDER est bien passée"
OldStr = Replace_MCL_Tool.TextBox1.Value
NewStr = Replace_MCL_Tool.TextBox2.Value
 
For Each Sh In ThisWorkbook.Worksheets
    MsgBox "La feuille <" & Sh.Name & "> est sélectionnée"
    On Error Resume Next
    For Each c In Sh.UsedRange.SpecialCells(xlCellTypeFormulas)
        c.Formula = Replace(c.Formula, OldStr, NewStr)
        MsgBox "La chaine de caractères <" & OldStr & "> a été remplacée par <" & NewStr & ">." & Chr(10) & _
        "La cellule <" & c.Address & "> contient la formule <" & c.Formula & ">."
    Next c
    On Error GoTo 0
Next Sh
Me.Hide
End Sub
Private Sub Annuler_Click()
    Me.Hide
End Sub
Cordialement.
gFZT82 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/10/2011, 14h31   #5
Membre du Club
 
Inscription : mars 2005
Messages : 181
Détails du profil
Informations personnelles :
Âge : 39
Localisation : France, Paris (Île de France)

Informations forums :
Inscription : mars 2005
Messages : 181
Points : 45
Points : 45
Ok

Donc après l'affichage MSGBOX
Code :
    MsgBox "La feuille <" & Sh.Name & "> est sélectionnée"
Le userForm se ferme et plus rien
lafafmentvotre est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/10/2011, 15h27   #6
Membre Expert
 
Homme
Retraité
Inscription : avril 2011
Messages : 692
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Activité : Retraité

Informations forums :
Inscription : avril 2011
Messages : 692
Points : 1 443
Points : 1 443
Première piste : le programme n’a pas trouvé de cellule contenant une formule à modifier dans la feuille sélectionnée.
gFZT82 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/10/2011, 15h41   #7
Membre du Club
 
Inscription : mars 2005
Messages : 181
Détails du profil
Informations personnelles :
Âge : 39
Localisation : France, Paris (Île de France)

Informations forums :
Inscription : mars 2005
Messages : 181
Points : 45
Points : 45
Hello

Pourtant la formule existe
Code :
=VLOOKUP(A12;'P:\@@@Travail\Projets\[Benchmark team.xls]FR_Site Inventory'!$A$3:$T$33;2;FALSE)
Dans ce test, je remplace P:\@@@Travail\ par P:\Toto\ mais rien ne se passe.

Je craque
lafafmentvotre est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/10/2011, 17h32   #8
Membre Expert
 
Homme Hervé Silve
Inscription : août 2010
Messages : 773
Détails du profil
Informations personnelles :
Nom : Homme Hervé Silve
Localisation : France

Informations forums :
Inscription : août 2010
Messages : 773
Points : 2 093
Points : 2 093
Bonjour,

Une piste :
tes formules Excel sont en Français ou en Anglais ?
dans le cas où c'est en Français, utilise FormulaLocal au lieu de Formula ou éventuellement FormulaR1C1Local ?

Hervé.
Theze est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/10/2011, 17h34   #9
Membre Expert
 
Homme
Retraité
Inscription : avril 2011
Messages : 692
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Activité : Retraité

Informations forums :
Inscription : avril 2011
Messages : 692
Points : 1 443
Points : 1 443
J'ai effectué un test avec la formule suivante en cellule A1 :

Code :
=RECHERCHEV(A12;'P:\@@@Travail\Projets\[Benchmark team.xls]FR_Site Inventory'!$A$3:$T$33;2;FAUX)
J'ai obtenu le résultat attendu :

Code :
=RECHERCHEV(A12;'P:\Toto\Projets\[Benchmark team.xls]FR_Site Inventory'!$A$3:$T$33;2;FAUX)
gFZT82 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/10/2011, 18h00   #10
Membre du Club
 
Inscription : mars 2005
Messages : 181
Détails du profil
Informations personnelles :
Âge : 39
Localisation : France, Paris (Île de France)

Informations forums :
Inscription : mars 2005
Messages : 181
Points : 45
Points : 45
Hello

Les formules sont en Anglais.

Point peut être important, ma macro qui appelle le userform ainsi que le userform sont dans le VBAProject (PERSONAL.XLSB) afin de pouvoir les utiliser avec n'importe quel fichier.

Je me serais planté ?
lafafmentvotre est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/10/2011, 15h32   #11
Modérateur
 
Avatar de AlainTech
 
Homme Alain Gerard
Consultant informatique
Inscription : mai 2005
Messages : 3 675
Détails du profil
Informations personnelles :
Nom : Homme Alain Gerard
Âge : 58
Localisation : Belgique

Informations professionnelles :
Activité : Consultant informatique
Secteur : Finance

Informations forums :
Inscription : mai 2005
Messages : 3 675
Points : 7 668
Points : 7 668
Bonjour,

Donc,
Code :
For Each Sh In ThisWorkbook.Worksheets
Fait référence aux feuilles présentes dans PERSONAL.XSLB.

Est-ce bien ce que tu veux?
__________________
N'oubliez pas de cliquer sur quand vous avez obtenu ou trouvé vous-même la réponse à votre question.
Si vous trouvez seul, pensez à poster votre solution. Elle peut servir à d'autres!
Pensez aussi à voter pour les réponses qui vous ont aidés.
------------
Je dois beaucoup de mes connaissances à mes erreurs!
AlainTech est déconnecté   Envoyer un message privé Réponse avec citation 20
Vieux 17/10/2011, 18h25   #12
Membre du Club
 
Inscription : mars 2005
Messages : 181
Détails du profil
Informations personnelles :
Âge : 39
Localisation : France, Paris (Île de France)

Informations forums :
Inscription : mars 2005
Messages : 181
Points : 45
Points : 45
Hello

En fait, je souhaiterais que cela fonctionne pour n'importe quel fichier que j'exécute avec la macro qui se trouve dans le Personal
lafafmentvotre est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/10/2011, 18h22   #13
Membre Expert
 
Avatar de aalex_38
 
Inscription : septembre 2007
Messages : 1 596
Détails du profil
Informations forums :
Inscription : septembre 2007
Messages : 1 596
Points : 1 748
Points : 1 748
Bonjour à tous,

Donc comme le signale Alain, il ne faut pas utiliser Thisworkbook, ce qui signifie le classeur dans lequel se trouve cette macro, mais une autre instanciation, pourquoi pas par exemple Activeworkbook ?
__________________
aalex_38 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/10/2011, 18h32   #14
Expert Confirmé
 
Homme Philippe
ex Observeur CGG / Analyste prog.
Inscription : juin 2006
Messages : 1 706
Détails du profil
Informations personnelles :
Nom : Homme Philippe
Localisation : France, Finistère (Bretagne)

Informations professionnelles :
Activité : ex Observeur CGG / Analyste prog.

Informations forums :
Inscription : juin 2006
Messages : 1 706
Points : 3 627
Points : 3 627
Salut, créer une macro complémentaire ( xla ) ? voir http://silkyroad.developpez.com/VBA/...Editor/#LIII-B http://excel.developpez.com/faq/?page=VBA
__________________
Pensez à Voter, d'avance merci. ( Pouces en bas à la droite de Citer )
Balisez votre code après l'avoir indenté sous Excel via Smart Indenter
Autre utilitaire : MZ Tools 3.0 VBA

Contribution : Excel / Word / PDF avec Adobe Acrobat Pro / PDFCreator 1 2
kiki29 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 05h04.


 
 
 
 
Partenaires

Hébergement Web