Rechercher : dans
Par :

Boucle checkbox vba excel

Dernière réponse le 16 avr 2008 à 21:02:30 guetteur, le 2 avr 2008 à 11:15:13 
 Signaler ce message aux modérateurs

Bonjour, je voudrais voir si des checkbox sont à vrai ou pas sur VBA pour excell. Mon gros problème est de faire boucler les checkbox il y en a une centaine.
Voilà mon code erroné

For i = 1 To 100

Dim a

If Feuil3.CheckBox"&i.Value = true Then
a = 1
End If

Next

ce qui marche c'est sans boucle:

If Feuil3.CheckBox1.Value = true Then
a = 1
End If

Merci de votre aide

Configuration: Windows XP
Internet Explorer 6.0

1

Xavstarblues, le 2 avr 2008 à 11:18:56
  • +1

Bonjour, il semble qu'il y ait un gros problème dans ta boucle, tu redefinis a chaque fois ta variable "a" et au final "a" ne te retourne true ou false que pour ta dernière checkbox P4 2.4, 512 DDR,Geforce 6200 AGP Win XP SP2|||P3 1 GHZ , 256 SDRAM, Debian Etch ||| P3 1Ghz , 392 SDRAM , Xubuntu 6.10
AMD Sempron 2600+,768 DRR , Win 2k|||AMD Athlon 64 X2 4200+, 2 Go DDR Ubuntu, Suse ou Solaris pas encore choisi

Répondre à Xavstarblues

2

guetteur, le 2 avr 2008 à 11:27:58

A oui pas con mais le problème réel ne vient pas de là. le problème vient de cet ligne

CheckBox"&i.

je ne sais pas comment appeler ma checkbox

Répondre à guetteur

3

amigo, le 2 avr 2008 à 12:13:06

Bonjour,

Voici un petit code qui pourra t'aider
il passe en revue tous les controles qui sont sur ton userform, et recupère la valeur des controles CheckBox, à toi d'en faire ce que tu as prévu.
j'ai affecté cette macro a CommandButton1, il faudra adapter.

Private Sub CommandButton1_Click()
Dim ctrl As control, nom As String
For Each ctrl In Me.Controls
  nom = ctrl.Name
  If InStr(nom, "CheckBox") = 1 Then
  MsgBox nom & " = " & ctrl.Value
End If
Next

Répondre à amigo

4

guetteur, le 2 avr 2008 à 13:17:59

Comment tu définis Me.Controls ??

Répondre à guetteur

5

guetteur, le 2 avr 2008 à 13:19:37

Parce que moi j'ai une erreur de compilation en écrivant Feuil.Controls

Répondre à guetteur

6

amigo, le 2 avr 2008 à 13:30:42

En fait ça marche sur un UserForm, pour une feuille je n'ai pas essayé, je cherche.

Répondre à amigo

7

guetteur, le 2 avr 2008 à 13:39:29

Et c'est quoi une userform.

Répondre à guetteur

8

guetteur, le 2 avr 2008 à 13:42:16

Ok j'ai trouvé je peux en insérer une mais c'est sur VBA. alors que moi j'ai placé mes 100 checkbox dans des cellules sous excel en face d'éléments que je veux "séléctionner".

Répondre à guetteur

9

guetteur, le 2 avr 2008 à 14:05:05

If Feuil3.CheckBox(i).Value = True Then
a = 1
End If

en faisant la phrase ne s'écrit pas en rouge mais si je lance la commande j'ai une erreur compil

Répondre à guetteur

10

arnokite, le 16 avr 2008 à 20:55:25
  • +1

Salut,

J'avais le même problème que toi et voilà comment je l'ai résolu, si cela peux t'aider:

Lorsque tu insères tes checkbox dans la feuille excel, tu fait un clic droit sur la checkbox, tu clic sur "Format de contrôle".
Dans l'onglet "Contrôle" tu associes une cellule de ta ligne à selectionner ex: Cellule Liée : C4.
Lorsque celle ci est associée, tu t'aperçois que lorsque la case à cocher est cochée, il apparait "VRAI" dans la cellule liée.
Il te reste à faire une boucle sur les lignes :

If Sheets("club").Range("C4").Offset(ligneclub, 0) = True Then
...

ligneclub = ligneclub+1

Il faut vérifier la cellule par "true" et non pas "VRAI" comme elle l'indique.

J'espère t'avoir aider....

@+++
Arnaud

Répondre à arnokite

11

 arnokite, le 16 avr 2008 à 21:02:30
  • +1

PS :

Cela te permet également de remettre toutes tes checkboxs à 0, tu met Faux dans la colonne sélectionnée.

@

Répondre à arnokite