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 :

Coller les valeurs d'un tableau de variables? [XL-2003]


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Distribution

    Informations forums :
    Inscription : Mai 2011
    Messages : 4
    Par défaut Coller les valeurs d'un tableau de variables?
    Bonjour,

    J'ai créé un fichier excel et je souhaite effectuer les calculs dans un tableau de variables et non sur ma feuille excel afin de réduire les temps de calcul (très longs).

    Je commence par créer et remplir mon tableau:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Dim tableau(1 To 23, 1 To 67) As Variant
    For i = 1 To UBound(tableau, 1)
        tableau(i, 1) = "=VLOOKUP(RC[28],Stock!R6C:R65536C[4],5,FALSE)"
        tableau(i, 2) = _
                    "=LEFT(VLOOKUP(RC[27],Stock!R6C[-1]:R65536C[1],3,FALSE),5)"
        ...
        ...
    Next i
    Par contre quand je recopie ce tableau sur ma feuille excel avec le code suivant, ce sont les formules qui se collent et non les valeurs, et du coup excel recalcule tout.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Range(Cells(7, 1), Cells(UBound(tableau, 1) + 6, UBound(tableau, 2))) = tableau
    Connaissez-vous une solution pour soit:
    - copier directement les valeurs du tableau sur ma feuille excel
    - remplacer les formules de mon tableau par leur valeur puis coller le tableau

    Merci.
    Florian.

  2. #2
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Distribution

    Informations forums :
    Inscription : Mai 2011
    Messages : 4
    Par défaut
    Bonjour Sypho,

    Si j'enlève les guillemets la formule est considérée comme du texte.
    Peut-être est-ce à cause de la syntaxe (remplacer RC[28] par tableau(i, 29) et Stock!R6C:R65536C[4] par un tableau de variables). Dans ce cas il faut que je crée 12 autres tableaux pour mes autres feuilles excel.

    Sinon je pense qu'il faudrait quelque chose comme:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    tableau(i, 1) = "=VLOOKUP(RC[28],Stock!R6C:R65536C[4],5,FALSE)"
    tableau(i, 1) = tableau(i, 1).value
    mais tableau(i, 1).value ne fonctionne pas.

    Avis aux experts...

  3. #3
    Membre émérite

    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    652
    Détails du profil
    Informations personnelles :
    Localisation : France, Ardèche (Rhône Alpes)

    Informations forums :
    Inscription : Octobre 2006
    Messages : 652
    Par défaut
    Bonjour

    essaies
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    tableau(i, 1) = Application.VLOOKUP(RC[28],Stock!R6C:R65536C[4],5,FALSE)
    Et pour restituer

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Cells(7,1).resize(23,67)=tableau

  4. #4
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Distribution

    Informations forums :
    Inscription : Mai 2011
    Messages : 4
    Par défaut
    Je viens de tester:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    tableau(i, 1) = Application.VLOOKUP(RC[28],Stock!R6C:R65536C[4],5,FALSE)
    Cette formule ne fonctionne pas (erreur de compilation: Attendu: séparateur de liste ou) ).
    Je pense que c'est à cause de RC[28] et Stock!R6C:R65536C[4] comme expliqué dans mon précédent post.

    Pour la seconde formule c'est bon mais comme la première ne fonctionne pas, j'ai toujours les formules et non les valeurs sur ma feuille excel.

  5. #5
    Membre émérite

    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    652
    Détails du profil
    Informations personnelles :
    Localisation : France, Ardèche (Rhône Alpes)

    Informations forums :
    Inscription : Octobre 2006
    Messages : 652
    Par défaut
    Suis je distrait, excuses moi !!!

    en fait il faut que tu utilises range
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Application.VLOOKUP(range("tacellule"),sheets("Stock"),range("R6C:R6.....
    nota: je suis perdu avec la notation RC mais tu peux reprendre la notation classique "A1"...

  6. #6
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Distribution

    Informations forums :
    Inscription : Mai 2011
    Messages : 4
    Par défaut
    Merci Michel ,

    J'ai donc créé un tableau par feuille excel, soit 12 tableaux:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Dim TableauABC As Variant
    i = Sheets("ABC").Range("A6").End(xlDown).Address
    i = Sheets("ABC").Range(i).Row
    If i = 65536 Then i = 6
    i = i - 5
    ReDim TableauABC(1 To i, 1 To 2)
    TableauABC = Range(Sheets("ABC").Cells(6, 1), Sheets("ABC").Cells(6 + i, 2))
    J'ai ensuite créé mon tableau "central" pour les calculs:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Dim TableauAcder As Variant
    i = Sheets("Stock").Range("A6").End(xlDown).Address
    i = Sheets("Stock").Range(i).Row
    If i = 65536 Then i = 6
    i = i - 5
    ReDim TableauAcder(1 To i, 1 To 65)
    Enfin je remplis mon tableau de valeurs:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    For i = 1 To UBound(TableauAcder, 1)
    TableauAcder(i, 29) = TableauStock(i, 1)
    TableauAcder(i, 1) = Application.VLookup(TableauAcder(i, 29), TableauStock, 5, False)
    ...
    Next i
    Et je colle mon tableau sur ma page excel, sans recalcul:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets("A cder").Cells(7, 1).Resize(i, 65) = TableauAcder
    Merci encore.

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

Discussions similaires

  1. [Toutes versions] VBA : coller les valeurs uniques d'un tableau virtuel en entêtes de colonnes
    Par thiefer dans le forum Excel
    Réponses: 4
    Dernier message: 16/05/2014, 18h03
  2. "inverser" les valeurs d'un tableau
    Par Clad3 dans le forum Algorithmes et structures de données
    Réponses: 6
    Dernier message: 12/12/2005, 12h13
  3. Réponses: 9
    Dernier message: 05/11/2005, 14h59
  4. comparer les valeurs d'un tableau
    Par nicerico dans le forum ASP
    Réponses: 4
    Dernier message: 19/08/2004, 11h20
  5. Compter les valeurs d'un tableau
    Par leeloo076 dans le forum ASP
    Réponses: 6
    Dernier message: 30/03/2004, 13h29

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