Précédent   Forum des professionnels en informatique > Logiciels > Microsoft Office > Excel
Excel Forum d'entraide sur Excel. Vos questions sur les fonctions, formules, manipulations, et tout sujet qui ne trouve pas sa place dans un sous-forum.
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 26/07/2011, 09h57   #1
Invité de passage
 
Homme
Ingénieur qualité méthodes
Inscription : juillet 2011
Messages : 16
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : Belgique

Informations professionnelles :
Activité : Ingénieur qualité méthodes
Secteur : High Tech - Électronique et micro-électronique

Informations forums :
Inscription : juillet 2011
Messages : 16
Points : 0
Points : 0
Par défaut emploie variable dans Application.Goto Reference

Bonjour à tous,
je cherche à employer une variable dans la fonction "Application.Goto Reference"

Mais je bloque actuellement.
Excel me renvoir une message d'erreur:
"Run-time error 1004:
Reference is not valid"

En réalité mon projet est plus large,
je cherche à récupérer les couleurs de fond d'une zone de champ, elle-même utilisé dans une liste déroulante via validation de données (ex en C10).

Dans certain cas, j'utilise des cascades de validation de données avec la fonction "INDIRECT" (ex en C11).

C'est pourquoi j'ai besoin d'une variable reprennant le résultat de la fonction Indirect.

Ci-joint le début de macro que j'ai réalisé et ainsi que le fichier Excel.
Je ne suis qu'un débutant dans la création de macro mais un grand fervant et professionnel d'Excel, c'est pourquoi je vous demanderai un peu d'indulgence dans ce domaine.

Merci d'avance à tous les mordus d'Excel.
duboisgs est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/07/2011, 11h34   #2
Nouveau Membre du Club
 
Inscription : mai 2006
Messages : 32
Détails du profil
Informations forums :
Inscription : mai 2006
Messages : 32
Points : 39
Points : 39
Bonjour,
Moi j'en suis là :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
Sub synoptic1()
Dim Nom_Z_C As String, o As Range
'sélectionner le contenu choisi dans la liste déroulante
Choix = ActiveCell.Value
'définition de la zone de champ correpondante à la datavalidation
Nom_Z_C = [C5] & "_reflectors"
' find du choix dans la zone de champ correspondant
With Worksheets("Global Synoptic").Range(Nom_Z_C)
Set o = .Find(Choix, LookIn:=xlValues)
End With
'sélectionner le code couleur de la cellule recherchée et l'appliquer au choix de la liste déroulente
ActiveCell.Interior.ColorIndex = o.Interior.ColorIndex
End Sub
... mais je ne manipule pas la validation de donnée. Dans ton exemple il ne semble pas que cela soit indispensable ?
A+
galopin01 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/07/2011, 11h54   #3
Invité de passage
 
Homme
Ingénieur qualité méthodes
Inscription : juillet 2011
Messages : 16
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : Belgique

Informations professionnelles :
Activité : Ingénieur qualité méthodes
Secteur : High Tech - Électronique et micro-électronique

Informations forums :
Inscription : juillet 2011
Messages : 16
Points : 0
Points : 0
Merci pour ton aide.

après remaniement, voici la version que je vais utiliser.
Elle me parait plus simple/allégé.

Merci encore

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
Sub synoptic()
'sélectionner le contenu choisi dans la liste déroulante
Choix = ActiveCell.Value
'définition de la zone de champ correpondante à la datavalidation
Nom_Z_C = ActiveCell.Validation.Formula1
 
' find du choix dans la zone de champ correspondant
 
With Range(Nom_Z_C) 'il n'est pas nécessaire de spécifier la feuille puisque une des force d'Excel est d'atteindre une zone de champ directement
Set o = .Find(Choix, LookIn:=xlValues)
End With
'sélectionner le code couleur de la cellule recherchée et l'appliquer au choix de la liste déroulente
ActiveCell.Interior.ColorIndex = o.Interior.ColorIndex
End Sub
duboisgs est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 07h35.


 
 
 
 
Partenaires

Hébergement Web