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 :

Choix avec Inputbox


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre très actif
    Homme Profil pro
    Inscrit en
    Avril 2012
    Messages
    116
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2012
    Messages : 116
    Par défaut Choix avec Inputbox
    Bonjour,

    J'ai mi en place un code VBA qui permet, dès l'ouverture du fichier Excel, de choisir entre deux types d'opération "investissement" ou "fonctionnement". Si l'on saisi "investissement", cela crée une nouvelle ligne dans la feuille "Investissement", si on tape "fonctionnement" cela crée une nouvelle ligne dans la feuille "fonctionnement".
    Voici le code :
    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
     
    Private Sub Workbook_Open()
     
    Dim i As Integer
    Dim j As Integer
     
     
    Choix1 = InputBox("Voulez-vous créer ou modifier une opération ? - tapez 'créer' ou 'modifier'")
     
    If Choix1 = "créer" Then
     
    Choix2 = InputBox("Entrez le type d'opération que vous voulez effectuer - tapez 'Investissement' ou 'Fonctionnement'")
     
    i = Range("B1018").End(xlUp).Row + 1
    i = IIf(i >= 19, i, 19)
    j = Range("B1018").End(xlUp).Row + 1
    j = IIf(j >= 19, j, 19)
     
            If Choix2 = "investissement" Then
            Feuil1.Range("B" & i).Value = Choix2
            Else: Feuil3.Range("B" & j).Value = Choix2
            End If
     
    Else
     
    End If
     
    i = i + 1
    j = j + 1
     
    End Sub
    Mon problème est que lorsque j'ouvre le fichier, si j'arrive dans la feuille "investissement", je ne peux pas créer de nouvelle ligne dans la feuille "fonctionnement"....et inversement.

    Voyez-vous de quoi ce problème peut venir ?

  2. #2
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Bonjour,
    Peut-être comme ça
    attention !, j'ai changé la variable choix1, tu feras comme tu l'entends
    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
    'si Feuil1 et Feuil3 ne sont pas des variables
    Private Sub Workbook_Open()
    Dim i As Integer, choix1 As Integer, Choix2 As String
    Dim j As Integer
    choix1 = InputBox("Voulez-vous créer ou modifier une opération ? - tapez 1 pour 'créer' ou 2 pour 'modifier'")
     
    If choix1 = 1 Then
      Choix2 = InputBox("Entrez le type d'opération que vous voulez effectuer - tapez 'Investissement' ou 'Fonctionnement'")
      i = Sheets("Feuil1").Range("B" & Sheets("Feuil1").Rows.Count).End(xlUp).Row + 1
      i = IIf(i >= 19, i, 19)
      j = Sheets("Feuil3").Range("B" & Sheets("Feuil3").Rows.Count).End(xlUp).Row + 1
      j = IIf(j >= 19, j, 19)
      If Choix2 = "investissement" Then
        Sheets("Feuil1").Range("B" & i).Value = Choix2
      Else
        Sheets("Feuil3").Range("B" & j).Value = Choix2
      End If
     
    Else
    '.........
    End If
     
    i = i + 1
    j = j + 1
     
    End Sub
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  3. #3
    Membre très actif
    Homme Profil pro
    Inscrit en
    Avril 2012
    Messages
    116
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2012
    Messages : 116
    Par défaut
    Merci pour ta réponse rapide.

    J'ai essayé ton code, ça me met une erreur d'éxécution (9)==>l'indice n'appartient pas à la sélection à cette ligne la :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    i = Sheets("Feuil1").Range("B" & Sheets("Feuil1").Rows.Count).End(xlUp).Row + 1

  4. #4
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Changes Feuil1 par le nom de ta feuille, idem pour feuil3 si ce ne sont pas les bons noms
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  5. #5
    Membre très actif
    Homme Profil pro
    Inscrit en
    Avril 2012
    Messages
    116
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2012
    Messages : 116
    Par défaut
    Oui c'est ça je venais de m'en rendre compte.

    Merci beaucoup ! Ca marche parfaitement.

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

Discussions similaires

  1. Recherche avec InputBox puis Copier - Coller de la ligne
    Par bungler dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 20/07/2007, 15h34
  2. [vba excel] liste de choix dans inputbox
    Par ancel17 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 02/07/2007, 11h06
  3. probleme avec inputbox
    Par white_wizzard dans le forum VBScript
    Réponses: 6
    Dernier message: 04/03/2007, 10h10
  4. Réponses: 2
    Dernier message: 01/08/2006, 13h38
  5. [VB6]Aide pour mettre format date avec inputbox
    Par Geliwy77 dans le forum VB 6 et antérieur
    Réponses: 13
    Dernier message: 28/01/2006, 20h13

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