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 :

Concaténation de variables


Sujet :

Macros et VBA Excel

  1. #1
    Candidat au Club
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    novembre 2020
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet MOA

    Informations forums :
    Inscription : novembre 2020
    Messages : 3
    Points : 2
    Points
    2
    Par défaut Concaténation de variables
    Bonjour,

    J'ai le code suivant pour Excel

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub CONCA()
    toto1 = 8
    toto2 = 14
    toto3 = 78
    toto4 = 90
     
    For lig = 2 To 6
    '
    'ci dessous : ne marche pas : Je voudrais concaténer toto avec le résultat de ma variable lig pour remplir tout mon tableau....Comment faire ? Quelle est la syntaxe ?
    Cells(lig, 2).Value = toto & (lig - 1)
    Next lig
     
    End Sub
    Merci

    Cordialement

  2. #2
    Expert éminent

    Homme Profil pro
    Curieux
    Inscrit en
    juillet 2012
    Messages
    4 958
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : juillet 2012
    Messages : 4 958
    Points : 9 645
    Points
    9 645
    Billets dans le blog
    5
    Par défaut
    Bonjour,

    tu utilises des variables totoX (X étant un nombre), non déclarées au passage, pour lesquelles tu affectes des valeurs

    et dans ta boucle, tu utilises une nouvelle variable toto qui n'est ni déclarée, ni affectée d'une quelconque valeur.

    Que cherches-tu exactement à faire avec tous ces totoX ? Et pourquoi ensuite utiliser un toto sorti de derrière les fagots ?

  3. #3
    Expert confirmé
    Homme Profil pro
    Electrotechnicien
    Inscrit en
    juillet 2016
    Messages
    2 672
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Electrotechnicien

    Informations forums :
    Inscription : juillet 2016
    Messages : 2 672
    Points : 4 674
    Points
    4 674
    Par défaut
    Bonsoir,

    Ceci , si j'ai bien compris
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub CONCA()
        toto1 = 8
        toto2 = 14
        toto3 = 78
        toto4 = 90
        For lig = 2 To 5
            Cells(lig, 2).Value = Application.WorksheetFunction.Choose(lig - 1, toto1, toto2, toto3, toto4)
        Next lig
    End Sub
    Cdlt

  4. #4
    Candidat au Club
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    novembre 2020
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet MOA

    Informations forums :
    Inscription : novembre 2020
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    Merci pour vos réponses mais Arturo83, je ne voudrais pas avoir à lister tous les toto, car j'en ai 50...
    et pour joe.levrai et tous, je vais essayer de clarifier

    J'ai une macro qui calcule 50 paramètres et les stocke dans 50 variables qu'on peut appeller toto1 à toto50....

    Je voulais, pour des raisons de test, mettre toto1 dans une cellule ligne 2, colonne 2 par exemple, toto2 la ligne 3 etc jusqu'à toto50..

    Soit je le fais à la main avec 50 lignes
    cells(2,2).value=toto1
    cells(3,2).value=toto2 etc...

    Ou je fais une boucle pour remplir mes cellules et je dis que
    lig=2
    cells(lig,2).value=toto "indice lig-1" avec totoindicelig-1=toto1 ! Et mon problème c'est que je ne sais pas concaténer toto avec lig-1 et que cela fasse toto1 !

    C'est possible ou pas ?

    Merci

    Cordialement

  5. #5
    Expert confirmé
    Homme Profil pro
    Electrotechnicien
    Inscrit en
    juillet 2016
    Messages
    2 672
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Electrotechnicien

    Informations forums :
    Inscription : juillet 2016
    Messages : 2 672
    Points : 4 674
    Points
    4 674
    Par défaut
    "]'ai une macro qui calcule 50 paramètres et les stocke dans 50 variables.........Je voulais mettre toto1 dans une cellule ligne 2, colonne 2 par exemple, toto2 la ligne 3 etc jusqu'à toto50..
    Alors, pourquoi passer par des variables intermédiaires? pourquoi ne pas mettre directement les 50 paramètres dans les cellules de destinations?

  6. #6
    Expert confirmé Avatar de Patrice740
    Homme Profil pro
    Retraité
    Inscrit en
    mars 2007
    Messages
    2 256
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : mars 2007
    Messages : 2 256
    Points : 4 948
    Points
    4 948
    Par défaut
    Bonjour,

    Utilises un tableau :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub CONCA()
    Dim toto(1 To 4)
      toto(1) = 8
      toto(2) = 14
      toto(3) = 78
      toto(4) = 90
      For lig = 1 To UBound(toto)
        Cells(lig + 1, 2).Value = toto(lig)
      Next lig
    End Sub
    Cordialement,
    Patrice
    Personne ne peut détenir tout le savoir, c'est pour ça qu'on le partage.

    Pour dire merci, cliquer sur et quand la discussion est finie, penser à cliquer sur

  7. #7
    Responsable
    Office & Excel


    Homme Profil pro
    Formateur et développeur informatique indépendant
    Inscrit en
    novembre 2003
    Messages
    16 589
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur informatique indépendant
    Secteur : Enseignement

    Informations forums :
    Inscription : novembre 2003
    Messages : 16 589
    Points : 47 782
    Points
    47 782
    Billets dans le blog
    88
    Par défaut
    Salut.

    comme Arturo, je me pose la question de l'utilité de passer par 50 variables si c'est, au final, pour les transférer dans des cellules. De plus, un exemple avec des toto1 et toto2 n'aide pas vraiment à se faire une idée de ce que tu as réellement comme situation ni de ce que tu veux réaliser. Ca nous permet uniquement de répondre à cette question étroite sans avoir une vue plus large de ton problème et donc, de ce que tu souhaites réellement obtenir.

    Cela dit, si tu as 50 paramètres à stocker, utilise plutôt un tableau qu'une suite de 50 variables. Pour valoriser le tableau, ce sera soit le même code que pour valoriser tes 50 variables soit une boucle si un algorithme peut être déterminé, mais tu pourras alors transférer ton tableau en une fois dans une plage.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub Test()
      Dim Toto(1 To 50, 1 To 1)
     
      Toto(1, 1) = "Bonjour"
      Toto(2, 1) = "Au revoir"
      '...
      '...
      Toto(50, 1) = "Dernier Toto"
      Range("c2:c51").Value = Toto
    End Sub
    Edit: Les grands esprits se rencontrent, Patrice... Perso, je passe par un tableau à deux dimensions pour valoriser ma plage sans boucle
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

Discussions similaires

  1. Algo de création de chaine par concaténation de variables
    Par Zhebulon dans le forum Algorithmes et structures de données
    Réponses: 2
    Dernier message: 13/04/2006, 15h37
  2. Réponses: 1
    Dernier message: 30/12/2005, 11h57
  3. Concaténation de variable ???
    Par dj-julio dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 20/12/2005, 15h10
  4. [SQL] Concaténation de variables
    Par dogi dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 01/11/2005, 21h49
  5. Concaténer deux variables ?
    Par glsn dans le forum ASP
    Réponses: 2
    Dernier message: 19/12/2003, 14h53

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