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

Access Discussion :

Recherche d'enregistrement via un formulaire


Sujet :

Access

  1. #1
    Membre du Club
    Inscrit en
    Août 2006
    Messages
    46
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 46
    Points : 44
    Points
    44
    Par défaut Recherche d'enregistrement via un formulaire
    Bonjour à tous,

    Le masque de recherche par défault d'access n'étant pas top je souhaite en faire un moi.

    Je n'ai besoin que d'1 critère de recherche.

    Mon idée :

    Je suis dans un formulaire dépendant déjà ouvert et je suis positionné sur l'enregistrement 1 et le champ X.

    J'ai créer un bouton recherche et je souhaitaiterais que sur l'évènement "sur click" de ce bouton s'ouvre une fenêtre type MonDossier= Inputbox("Saisir n° de Dossier").

    Je récupére cette variable qui me sert à chercher mon enregistrement et à me positionner dessus, le curseur devant se trouver sur le champ X qui n'est pas le champ en tête du formulaire.

    C'est sur cette dernière phrase que j'ai un peu de mal à m'en sortir.

    Merci de votre aide.

  2. #2
    pgz
    pgz est déconnecté
    Expert éminent Avatar de pgz
    Homme Profil pro
    Développeur Office VBA
    Inscrit en
    Août 2005
    Messages
    3 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 70
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Office VBA
    Secteur : Conseil

    Informations forums :
    Inscription : Août 2005
    Messages : 3 692
    Points : 6 591
    Points
    6 591
    Par défaut
    Bonjour,

    Je récupére cette variable qui me sert à chercher mon enregistrement et à me positionner dessus, le curseur devant se trouver sur le champ X qui n'est pas le champ en tête du formulaire.

    C'est sur cette dernière phrase que j'ai un peu de mal à m'en sortir.
    EN clair, qu'est-ce que tu n'arrives pas à faire :
    - te positionner sur l'enregistrement
    - ou laisser le curseur dans le contrôle où il était?

    PGZ
    pluritas non est ponenda sine necessitate - Le rasoir d'Okham
    Ne jamais attribuer à la malignité ce que la stupidité peut expliquer -Le rasoir d'Hanlon

  3. #3
    Membre du Club
    Inscrit en
    Août 2006
    Messages
    46
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 46
    Points : 44
    Points
    44
    Par défaut
    Jusqu'à inputbox ça va, mais après je ne sais pas comment programmer en VB pour récupérer la variable et l'utiliser pour me positionner sur le bon enregistrement et sur le bon champ.

    Merci

  4. #4
    pgz
    pgz est déconnecté
    Expert éminent Avatar de pgz
    Homme Profil pro
    Développeur Office VBA
    Inscrit en
    Août 2005
    Messages
    3 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 70
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Office VBA
    Secteur : Conseil

    Informations forums :
    Inscription : Août 2005
    Messages : 3 692
    Points : 6 591
    Points
    6 591
    Par défaut
    Re,

    Ce n'est pas trop difficile, sauf un point :
    quand tu vas cliquer sur ton bouton de commande, le contrôle qui était actif va perdre le focus et c'est bien ennuyeux!

    Pour éviter cela, il ne faut pas utiliser un contrôle bouton de commande, mais par exemple une étiquette. Pour la présentation, tu peux lui donner une apparence 'en relief'. Cette étiquette tu l'appelles MonBouton et sur évènement click
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Private Sub MonBouton_Click()
    Dim ctl As Control, str As String
     
    str = InputBox("num dossier?")
    If Nz(str, "") = "" Then Exit Sub
     
    Set ctl = Me.ActiveControl
    Me.IdDossier.SetFocus
    DoCmd.FindRecord str, acEntire, , acSearchAll, , acCurrent
    ctl.SetFocus
     
    End Sub
    En considérant que le numéro de dossier est dans un champ IdDossier.

    Il y a d'autres façons de faire...

    Bon courage,

    PGZ
    pluritas non est ponenda sine necessitate - Le rasoir d'Okham
    Ne jamais attribuer à la malignité ce que la stupidité peut expliquer -Le rasoir d'Hanlon

  5. #5
    Membre du Club
    Inscrit en
    Août 2006
    Messages
    46
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 46
    Points : 44
    Points
    44
    Par défaut
    Je te remercie pour le code, ça marche nickel sans rien "ajouter ni retirer", comme je souhaitais.

    Merci encore

    Pat04

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

Discussions similaires

  1. [AC-2010] Sauvegarder un enregistrement via un formulaire
    Par lucky01 dans le forum VBA Access
    Réponses: 4
    Dernier message: 30/03/2012, 10h21
  2. [AC-2007] Enregistrement via un formulaire
    Par GregShakur dans le forum IHM
    Réponses: 3
    Dernier message: 02/01/2010, 20h26
  3. Réponses: 2
    Dernier message: 26/04/2008, 19h32
  4. [VBA] MAJ d'un enregistrement via un formulaire
    Par Minet dans le forum Access
    Réponses: 5
    Dernier message: 09/03/2006, 20h40
  5. Rechercher un enregistrement via un form
    Par priest69 dans le forum IHM
    Réponses: 2
    Dernier message: 28/11/2005, 10h36

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