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 :

Mise a jour de données via formulaire


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    82
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 82
    Par défaut Mise a jour de données via formulaire
    Bonjour,

    J'ai un userform qui me permet d'afficher les données de ma Feuil

    J'ai mis un bouton pour pouvoir enregistrer les modifications

    soit:
    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
    Private Sub CommandButton2_Click()
    Dim Lig As Long
    Dim ws As Worksheets
    Set ws = Worksheets("Feuil1")
     
    ws.Cells(Lig, 1).Value = Me.Nom.Value
    ws.Cells(Lig, 2).Value = Me.photo.Value
    ws.Cells(Lig, 3).Value = Me.Tph.Value
    ws.Cells(Lig, 4).Value = Me.valmarch.Value
    ws.Cells(Lig, 5).Value = Me.prixht.Value
    ws.Cells(Lig, 6).Value = Me.livraison.Value
    ws.Cells(Lig, 7).Value = Me.tva.Value
    ws.Cells(Lig, 8).Value = Me.etattva.Value
    ws.Cells(Lig, 9).Value = Me.prixttc.Value
    ws.Cells(Lig, 10).Value = Me.ventemin.Value
    ws.Cells(Lig, 11).Value = Me.venteestim.Value
    ws.Cells(Lig, 12).Value = Me.ecart.Value
     
    End Sub
    A chaque fois j'obtien une erreur "91" sur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ws.Cells(Lig, 1).Value = Me.Nom.Value
    J'ai lu plusieurs poste et l'aide mais je n'arrive pas as identifier le probleme.

    Pourriez vous m'aider? Merci

  2. #2
    Membre Expert
    Femme Profil pro
    Data engineer
    Inscrit en
    Juin 2007
    Messages
    673
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Data engineer
    Secteur : Conseil

    Informations forums :
    Inscription : Juin 2007
    Messages : 673
    Par défaut
    Bonjour,
    La variable Lig n'est pas initialisée... Qu'est-ce qu'elle est sensée contenir ?

  3. #3
    pgz
    pgz est déconnecté
    Expert confirmé 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 : 72
    Localisation : France

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

    Informations forums :
    Inscription : Août 2005
    Messages : 3 692
    Par défaut
    Bonsoir.

    Avec le code que tu donnes, Lig vaut 0, et la ligne 0 n'existe pas.

    Cordialement,

    PGZ

  4. #4
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    82
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 82
    Par défaut
    Je ne suis pas très bon en VBA

    J'avoue être complètement perdu. De se que j'ai compris "Lig" me permet d'écrire sur une ligne et qu'il reste a définir la colonne par son numéro.

  5. #5
    Expert confirmé
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Par défaut
    Bonjour,
    Citation Envoyé par crashfire Voir le message
    JDe se que j'ai compris "Lig" me permet d'écrire sur une ligne et qu'il reste a définir la colonne par son numéro.
    Oui c'est bien ça mais, comme l'ont signalé pgz et tedo01, si tu n'attribues pas de valeur à ta variable "Lig", par défaut Lig = 0
    Donc ws.Cells(Lig, 1) correspond à ws.Cells(0, 1) et la ligne 0 n'existe pas, d'où le plantage.

    Essaie ceci
    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 CommandButton2_Click()
    Dim Lig As Long
    Dim ws As Worksheets
    Set ws = Worksheets("Feuil1")
    Lig = 10
     
    ws.Cells(Lig, 1).Value = Me.Nom.Value
    ws.Cells(Lig, 2).Value = Me.photo.Value
    ws.Cells(Lig, 3).Value = Me.Tph.Value
    ws.Cells(Lig, 4).Value = Me.valmarch.Value
    ws.Cells(Lig, 5).Value = Me.prixht.Value
    ws.Cells(Lig, 6).Value = Me.livraison.Value
    ws.Cells(Lig, 7).Value = Me.tva.Value
    ws.Cells(Lig, 8).Value = Me.etattva.Value
    ws.Cells(Lig, 9).Value = Me.prixttc.Value
    ws.Cells(Lig, 10).Value = Me.ventemin.Value
    ws.Cells(Lig, 11).Value = Me.venteestim.Value
    ws.Cells(Lig, 12).Value = Me.ecart.Value
     
    End Sub

  6. #6
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    82
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 82
    Par défaut
    ok je comprend le logique
    Mais en definissant Lig=1 vas t il ecrire sur la premiere ligne?
    Car moi je voudrais qu'il remplace les donner que j'ai modifier et cela peux etre sur n'importe qu'elle ligne

  7. #7
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Il faudrait déclarer Lig en début de module (variable globale)
    Comment tu récupère les données dans ton userform à partir de ta feuille pour les modifier?
    Si c'est ça, tu affecte à Lig la valeur de la ligne à modifier, tu fais tes modifs et le ré enregistrement se fera au bon endroit

Discussions similaires

  1. [AC-2003] Mise à jour d'une donnée via formulaire
    Par Lafouine4478 dans le forum IHM
    Réponses: 6
    Dernier message: 21/02/2011, 08h22
  2. [MySQL] Affichage et mise a jour de données via un lien
    Par argon dans le forum PHP & Base de données
    Réponses: 12
    Dernier message: 29/06/2008, 12h30
  3. mise a jour des données d'un formulaire
    Par imeys dans le forum IHM
    Réponses: 3
    Dernier message: 28/08/2007, 22h57
  4. Mise à jour de tables via formulaire
    Par sunwind dans le forum IHM
    Réponses: 4
    Dernier message: 09/12/2006, 20h09
  5. Mise à jour champs modifés via formulaire
    Par Al3x dans le forum Requêtes
    Réponses: 2
    Dernier message: 02/01/2006, 17h31

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