IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macros et VBA Excel Discussion :

Userform - recherche de l'aide [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Contrôleur de gestion
    Inscrit en
    Février 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur de gestion

    Informations forums :
    Inscription : Février 2014
    Messages : 13
    Par défaut Userform - recherche de l'aide
    Tout d'abord bonjour à tous,

    Je suis sur la conception d'un tableau de gestion des congés qui a bien avancé.
    Je débute en VBA et je rencontre un soucis.

    Mon fichier : http://dl.free.fr/q96EIQAYK

    Dans l'onglet "saisie" j'ai mis un bouton "Ajouter un congé" qui appel un UserForm.
    Quand on clique dessus une fenêtre Userform s'ouvre avec 5 champs



    Premier champ : une liste déroulante qui permet de sélectionner une des personnes nommer dans la colonne A de la feuille "Saisie" ici j'ai pu le faire.
    Second champ : Une liste déroulante pour sélectionner le mois qui sont des feuilles.
    Troisième champ : on entre la date de début de congé, exemple "2/01"
    Quatrième champ : on entre la date de fin de congé, exemple "4/01"
    Cinquième champ : on entre le code congés qui s'affichera dans les dates choisies dans les champs 3 et 4 soit du 02/01 au 04/01 exemple "RE"

    Je ne sais pas si c'est évident car cela veut dire une fonction recherche (je ne sais pas si c'est possible) qui recherche la feuille via le mois puis le nom sélectionner qui défini donc la ligne puis il recherche les dates saisies pour définir les colonnes.
    Une fois les les cases défini par la recherche trouver cela inscrit le code congés tapé dans le champ 5.

    Merci pour votre aide.

  2. #2
    Membre chevronné
    Homme Profil pro
    autodidacte
    Inscrit en
    Novembre 2013
    Messages
    517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : autodidacte
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2013
    Messages : 517
    Par défaut
    voici un bout de code qui permet de rechercher des valeurs et récupérer les valeurs trouvées sur la ligne:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    Public C As Range
    Public n As Integer
     
    Private Sub CommandButton1_Click()
     
    Set C = Worksheets("nomdelafeuille").Range("A2:A20000").Find(TextBox1.Value, LookIn:=xlValues, LookAt:=xlWhole, SearchOrder:=xlByRows, SearchDirection:=xlNext, MatchCase:=False) ' Remplacer Range("A2:A20000") par là ou ca doit chercher et Find(TextBox1.Value) par le textbox ou combobox qui aura la valeur à chercher
     
        ' Si le nom est déjà dans le classeur:
     
        If Not C Is Nothing And Not IsEmpty(C) Then
            n = C.Row
        UserForm1.TextBox1.Value = Sheets("nomdetafeuille").Cells(n, "A").Value
        UserForm1.TextBox2.Value = Sheets("nomdetafeuille").Cells(n, "B").Value
        UserForm1.Combobox3.Value = Sheets("nomdetafeuille").Cells(n, "C").Value
     
                Else
            X = MsgBox("Pas de valeurs trouvées. Voulez vous entrer ces données dans la base de données? ", vbYesNo)
     
     If X = 6 Then ' si oui est cliqué, alors X=6 
    Dim LigFin As Long
    Dim iRow As Long
    Dim ws As Worksheet
    Set ws = Worksheets("nomdetafeuille")
    Application.ScreenUpdating = False
    If ActiveSheet.AutoFilterMode = True Then
        ActiveSheet.AutoFilterMode = False
        End If
     
    LigFin = Sheets("nomdetafeuille").Cells(Rows.Count, 1).End(xlUp).Row
     
    IntLigne = ActiveSheet.Cells(2, 1).End(xlUp).Row + 1
    Dim Lg As String
     
    Lg = Sheets("nomdetafeuille").Cells(65500, 1).End(xlUp).Row + 1
     
    Sheets("nomdetafeuille").Cells(Lg, "A").Value = UserForm1.TextBox1.Value
    Sheets("nomdetafeuille").Cells(Lg, "B").Value = UserForm1.TextBox2.Value
    Sheets("nomdetafeuille").Cells(Lg, "C").Value = UserForm1.TextBox3.Value
            Else
            GoTo fin
            End If
     
    End If
    fin:
    End Sub

  3. #3
    Membre éprouvé Avatar de defluc
    Homme Profil pro
    Architecte
    Inscrit en
    Mai 2002
    Messages
    1 383
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 76
    Localisation : Belgique

    Informations professionnelles :
    Activité : Architecte

    Informations forums :
    Inscription : Mai 2002
    Messages : 1 383
    Par défaut
    Pour éviter les erreurs d'entrée de données, j'utiliserais des contrôles calendrier pour les dates de début et de fin de congé et un ComboBox pour les codes de congés rempli comme suit
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    Private Sub UserForm_Initialize()
      ComboBox1.RowSource = ("Noms")
      ComboBox2.AddItem "Janvier"
      ComboBox2.AddItem "Février"
      ComboBox2.AddItem "Mars"
      ComboBox2.AddItem "Avril"
      ComboBox2.AddItem "Mai"
      ComboBox2.AddItem "Juin"
      ComboBox2.AddItem "Juillet"
      ComboBox2.AddItem "Août"
      ComboBox2.AddItem "Septembre"
      ComboBox2.AddItem "Octobre"
      ComboBox2.AddItem "Novembre"
      ComboBox2.AddItem "Décembre"
      ComboBox3.AddItem "CP"
      ComboBox3.AddItem "PA"
      ComboBox3.AddItem "ED"
      ComboBox3.AddItem "SO"
      ComboBox3.AddItem "RE"
    End Sub

  4. #4
    Membre averti
    Homme Profil pro
    Contrôleur de gestion
    Inscrit en
    Février 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur de gestion

    Informations forums :
    Inscription : Février 2014
    Messages : 13
    Par défaut
    Merci pour les réponses mais cela ne fonctionne pas ainsi

  5. #5
    Membre éprouvé Avatar de defluc
    Homme Profil pro
    Architecte
    Inscrit en
    Mai 2002
    Messages
    1 383
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 76
    Localisation : Belgique

    Informations professionnelles :
    Activité : Architecte

    Informations forums :
    Inscription : Mai 2002
    Messages : 1 383
    Par défaut
    Expliques-toi, ça doit fonctionner.

  6. #6
    Membre averti
    Homme Profil pro
    Contrôleur de gestion
    Inscrit en
    Février 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur de gestion

    Informations forums :
    Inscription : Février 2014
    Messages : 13
    Par défaut
    Salut Defluc,

    Pour le code de contrôle je l'ai mis et cela me donne une erreur d'exécution '424' objet requis, quand j'enclenche le bouton.

    Et pour le code de bboy, la je ne comprend pas tout le code.

    Set C = Worksheets("nomdelafeuille").Range("A2:A20000")
    La recherche doit se faire sur toutes les feuilles et la c'est sur 1 seule feuille ? (il y a 12 feuilles)

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 1
    Dernier message: 23/05/2007, 22h12
  2. [VBA-E]Editer UserForm Recherche
    Par ananar dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 10/05/2007, 14h50
  3. [Dates] recherche script et aide bonus aux clics
    Par oceanne dans le forum Langage
    Réponses: 15
    Dernier message: 01/05/2007, 11h20
  4. [AJAX] [recherche] tutoriaux et aide AJAX
    Par yanchasp dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 29/05/2006, 16h13
  5. Recherche recursive à l'aide des expressions reguliére
    Par titoff dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 20/12/2005, 16h42

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo