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 :

Initialisation d'un tableau


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre chevronné
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    424
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 424
    Par défaut
    Bonjour,

    Je dois initialiser un tableau à 2 dimensions de la facon suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    t = Array(Array(1, xlTextFormat), Array(2, xlTextFormat), ... , Array(n, xlTextFormat)
    Sachant que n est une variable

    Existe t-il une syntaxe simple qui tiendrais dans une seule instruction ou est-on obligé de faire une boucle ?

    Je dois passer ce tableau en argument d'une fonction, c'est pourquoi je voulais éviter de faire une boucle et le passer direct.

    Merci

    Même avec une boucle je trouve pas la syntaxe

  2. #2
    Membre chevronné
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    424
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 424
    Par défaut
    En recherchant dans le forum j'ai trouve ce post ou AlainTech donne une solution mais pour moi, ca ne marche, j'ai une erreur d'excution 13 (imcompatibilité de type) au moment de l'affectation

    J'ai fait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Dim t As Variant
    For c = 1 To col
      t(c) = Array(c, xlTextFormat)
    Next c

  3. #3
    Membre émérite

    Profil pro
    Inscrit en
    Mai 2007
    Messages
    514
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 514
    Par défaut
    Bonjour,

    Si tu veux un tableau de tableaux:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Dim t()
    col = 5
    Redim t(1 To col)
    For c = 1 To col
      t(c) = Array(c, xlTextFormat)
    Next c
    MsgBox t(1)(0) '0 car Array renvoie un tableau indice a partir de 0
    Si tu veux un tableau a deux dimensions:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Dim t()
    col = 5
    Redim t(1 to 2, 1 to col)
    For c = 1 To col
      t(1,c) = c
      t(2,c) = xlTextFormat
    Next c
    MsgBox t(1, 1)
    Personellement, je préfere la deuxieme option.

    Cordialement,

    Tirex28/

  4. #4
    Membre chevronné
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    424
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 424
    Par défaut
    Merci pour ces infos

    Apparemment on peux aussi écrire pour le tableau de tableau et pour le tableau à 2 dimensions.

    Je préfère aussi la 2ème option, mais dans ce cas je n'ai pas le choix car c'est pour passer l'argument FieldInfo de la méthode TextToColumns qui demande ce format la.

    Merci encore

  5. #5
    Membre chevronné

    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    453
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 453
    Par défaut
    Le problème est-il résolu???

  6. #6
    Membre chevronné
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    424
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 424
    Par défaut
    Après différent essais j'ai compris la différence

    Redim (1 to col) --> l'indice commence à 1
    Redim (col) --> l'indice commence à 0

    Dans mon cas je dois faire Redim (col-1)

    Merci encore

  7. #7
    Membre chevronné
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    424
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 424
    Par défaut
    oui merci Singular

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

Discussions similaires

  1. Initialisation d'un tableau à plusieurs dimensions
    Par kinouseb dans le forum Windows Forms
    Réponses: 2
    Dernier message: 07/02/2007, 13h16
  2. Initialisation d'un tableau de pointeurs
    Par tintin72 dans le forum C++
    Réponses: 19
    Dernier message: 19/11/2006, 10h22
  3. Problème d'initialisation d'un tableau
    Par Premium dans le forum C
    Réponses: 13
    Dernier message: 31/05/2006, 14h48
  4. Débutant : initialisation d'un tableau
    Par lebokto dans le forum C++
    Réponses: 7
    Dernier message: 02/11/2005, 15h50
  5. Initialisation d'un tableau de type STRUCT
    Par Axiome dans le forum MFC
    Réponses: 4
    Dernier message: 06/09/2005, 10h58

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