Ceci est une page optimisée pour les mobiles. Cliquez sur ce texte pour afficher la vraie page.

XL 2019 Tableau index vers valeur

  • Initiateur de la discussion Initiateur de la discussion Hoareau
  • Date de début Date de début

Hoareau

XLDnaute Occasionnel
Bonjour
Le code si dessous me donne :
10 20 30 40
alors que je voudrais les index 2,4,6,8 de array value
merci
code:
Option Base 1

Sub Index_to_Value()

Dim Array_Index()
Dim Array_Value()
Dim Array_Destination()

Array_Index = Array(2, 4, 6, 8)
Array_Value = Array(10, 20, 30, 40, 50, 60, 70, 80, 90, 100)
ReDim Array_Destination(UBound(Array_Index))

For i = LBound(Array_Index) To UBound(Array_Index)
Array_Destination(i) = Array_Value(i)
Next
[C10].Resize(, UBound(Array_Destination)) = Array_Destination


End Sub

code:
Option Base 1

Sub Index_to_Value()

Dim Array_Index()
Dim Array_Value()
Dim Array_Destination()

Array_Index = Array(2, 4, 6, 8)
Array_Value = Array(10, 20, 30, 40, 50, 60, 70, 80, 90, 100)
ReDim Array_Destination(UBound(Array_Index))

For i = LBound(Array_Index) To UBound(Array_Index)
Array_Destination(i) = Array_Value(i)
Next


[C10].Resize(, UBound(Array_Destination)) = Array_Destination


End Sub
 

Hasco

XLDnaute Barbatruc
Repose en paix
Bonjour,

VB:
Sub Index_to_Value()

    Dim Array_Index()
    Dim Array_Value()
    Dim Array_Destination()
    Dim i As Integer
   
    Array_Index = Array(2, 4, 6, 8)
    Array_Value = Array(10, 20, 30, 40, 50, 60, 70, 80, 90, 100)
    ReDim Array_Destination(UBound(Array_Index))

    For i = LBound(Array_Index) To UBound(Array_Index)
        ' Récupérer la valeur correspondant à Array_index(i)
        Array_Destination(i) = Array_Value(Array_Index(i))
    Next
    '
    ' En base 0 rajouter 1 à ubound (Les tableaux de cellules sont en base 1)
    [C10].Resize(, UBound(Array_Destination) + 1) = Array_Destination


End Sub

Cordialement
 

Hoareau

XLDnaute Occasionnel
je vous remercie quadruplement
-j'ai eu une réponse
-j'ai eu une réponse rapide à laquelle, je n'ai pu répondre rapidement
- j'ai une une réponse qui correspond à ce que je voulais
-et des explications

Mis à part cela, ce bout de code, fera parti, si je réussi, d'une fonction perso Top n valeur
(Plage d'entrée range,Top n )
sortie en deux tableaux Top n valeur Valeur,rang(Index)' (rank ne passant pas sur les tabeaux)



 

Hoareau

XLDnaute Occasionnel
Bonjour
Un problème que j'avais oublié , les N° différents avec les mêmes index
ex :
Array_Index = Array(1, 1, 1, 8)
me renvoi :

10​
10​
10​
80​
Alors que le résultat est :
10, 20, 30, 80

merci

 

Hoareau

XLDnaute Occasionnel
Pas exactement, mais je me disais que peut être, il y avait un moyen, de contourner
en disant par exemple que si a déjà été affecté prendre le second etc...
Plus facile à dire qu'à faire
 

patricktoulon

XLDnaute Barbatruc
Bonjour @Roblochon @Hoareau

juste comme ça en passant
on peut très bien récupérer les éléments distincts d'un array sans boucle

demo
VB:
Sub test()

    Dim Array_Index, Array_Value, Array_Destination

    Array_Index = Array(2, 4, 6, 8)

    Array_Value = Array(10, 20, 30, 40, 50, 60, 70, 80, 90, 100)

    'Array_Destination = Application.Index(Array_Value, Evaluate("Row(1:1)"), Array_Index)
    
    'ou sans evaluate
    
    Array_Destination = Application.Index(Array_Value, 0, Array_Index)


   MsgBox "le LBOUND de Array_Destination est " & LBound(Array_Destination) & vbCrLf & Join(Array_Destination, "-")
End Sub
j'attire votre attention sur le fait que d'utiliser app.index ou même evaluate fait que vba va travailler automatiquement en base 1

la seule différence entre les deux méthodes c'est que l'index de ligne ( 0 ou Evaluate("Row(1:1)")) est en base réelle sans evaluate soit 0
 
Dernière édition:

mapomme

XLDnaute Barbatruc
Supporter XLD
Bonjour @Hoareau , @Roblochon ; @patricktoulon

Une tentative pour votre deuxième demande.
Les hypothèses:
  • Option Base peut-être à 0 ou 1
  • Dans le tableau index, les index commencent à 1 (à priori d'après ce que j'ai compris) : 1 correspond au premier élément des valeurs.
  • Dans le tableau des index, les index ne sont pas forcément triés en ordre croissant
  • Le premier index 1 rencontré, renvoie la première valeur du tableau des valeurs
  • Les 1 suivants renvoient la valeur d'index de l'élément précédent augmenté de 1
Ce qui donne par exemple :


Le code :
VB:
Sub N_Index()
Dim Array_Index, Array_Value, i As Long, decal&, oldIndex&, newindex&, dejaUn As Boolean
   Array_Index = Array(2, 4, 6, 8)           '  (2,4,6,8)  (1,1,1,8) (2,1,1,8) (2,1,1,5,8,1,3)

   Array_Value = Array(10, 20, 30, 40, 50, 60, 70, 80, 90, 100)
   ReDim Array_Destination(UBound(Array_Index))

   If LBound(Array_Index) = 0 Then decal = -1 Else decal = 0
   newindex = Array_Index(LBound(Array_Index))
   Array_Destination(LBound(Array_Index)) = Array_Value(newindex + decal)
   oldIndex = newindex: dejaUn = oldIndex = 1

   For i = LBound(Array_Index) + 1 To UBound(Array_Index)
      If Array_Index(i) = 1 Then
         If dejaUn Then
            newindex = oldIndex + 1
         Else
            newindex = 1
            dejaUn = True
         End If
      Else
         newindex = Array_Index(i)
      End If
      Array_Destination(i) = Array_Value(newindex + decal)
      oldIndex = newindex
   Next i
   Range(Range("c10"), Cells(10, Columns.Count).End(xlToLeft)).ClearContents
   [C10].Resize(, UBound(Array_Destination) - LBound(Array_Destination) + 1) = Array_Destination
End Sub
 

mapomme

XLDnaute Barbatruc
Supporter XLD
Re,

Une généralisation : L'index 1 ne joue un rôle particulier; Tous les index suivent la même règle:
  • Quand on rencontre pour la première fois un index, on retourne la valeur correspondant à cet index.
  • Quand on on rencontre un index pour la seconde fois (ou plus), alors on retourne la valeur correspondant à l'index de la valeur précédente +1
Ce qui donne (voir le dernier cas) :


Le code :
VB:
Sub N_Index()
Dim Array_Index, Array_Value, i As Long, decal&, oldIndex&, newindex&, dejaUn As Boolean
   Array_Index = Array(2, 4, 4, 4, 3, 3, 1, 8)        '(2, 4, 6, 8) (1, 1, 1, 8) (2, 1, 1, 8) (2, 1, 1, 5, 8, 1, 3) (2, 4, 4, 4, 3, 3, 1, 8)
   Array_Value = Array(10, 20, 30, 40, 50, 60, 70, 80, 90, 100)
   ReDim Array_Destination(UBound(Array_Index))
   ReDim dejaVu(LBound(Array_Value) To UBound(Array_Value))

   If LBound(Array_Index) = 0 Then decal = -1 Else decal = 0
   newindex = Array_Index(LBound(Array_Index))
   Array_Destination(LBound(Array_Index)) = Array_Value(newindex + decal)
   oldIndex = newindex
   dejaVu(newindex) = True

   For i = LBound(Array_Index) + 1 To UBound(Array_Index)
      If dejaVu(Array_Index(i)) Then
         newindex = oldIndex + 1
      Else
         newindex = Array_Index(i)
         dejaVu(Array_Index(i)) = True
      End If
      Array_Destination(i) = Array_Value(newindex + decal)
      oldIndex = newindex
   Next i
   Range(Range("c10"), Cells(10, Columns.Count).End(xlToLeft)).ClearContents
   [C10].Resize(, UBound(Array_Destination) - LBound(Array_Destination) + 1) = Array_Destination
End Sub
 
Dernière édition:

patricktoulon

XLDnaute Barbatruc
re
je pige pas très bien l’intérêt de tout ça mais soit
VB:
Sub testX()
    Dim Array_Index, Array_Value

    Array_Value = Array(10, 20, 30, 40, 50, 60, 70, 80, 90, 100)

    GetarrayValue Array(2, 4, 6, 8), Array_Value                ' test1
    GetarrayValue Array(1, 1, 1, 8), Array_Value                ' test2
    GetarrayValue Array(2, 1, 1, 8), Array_Value                ' test3
    GetarrayValue Array(2, 1, 1, 5, 8, 1, 3), Array_Value       ' test4
    GetarrayValue Array(2, 4, 4, 4, 3, 3, 1, 8), Array_Value    ' test5

End Sub

Sub GetarrayValue(Array_Index, Array_Value)
    Dim Array_Destination, Array_Indexbis
    ReDim Array_Indexbis(UBound(Array_Index)): Array_Indexbis(0) = Array_Index(0)
    For i = 1 To UBound(Array_Index)
        Array_Indexbis(i) = IIf(Array_Index(i) = Array_Index(i - 1), Array_Indexbis(i - 1) + 1, Array_Index(i))
    Next
    Array_Destination = Application.Index(Array_Value, 0, Array_Indexbis)
    With Cells(Rows.Count, 1).End(xlUp).Offset(1)
        .Value = "(" & Join(Array_Index, ",") & ")"
        .Offset(, 1).Resize(1, UBound(Array_Indexbis) + 1) = Array_Destination
    End With
End Sub

 

mapomme

XLDnaute Barbatruc
Supporter XLD
QUOTE="patricktoulon, post: 20340662, member: 167882"]
je pige pas très bien l’intérêt de tout ça mais soit
[/QUOTE]
Moi non plus.
C'est pas tout fait équivalent à ce que j'ai fait mais je préfère ton interprétation (qui est d'ailleurs beaucoup plus simple). Comme on ne connaît pas la finalité...
 
Dernière édition:

Discussions similaires

Réponses
33
Affichages
2 K
  • Question Question
Microsoft 365 Générer mail via Excel
Réponses
2
Affichages
680
  • Question Question
Microsoft 365 SOMMEPROD en vba excel
Réponses
12
Affichages
460
  • Question Question
XL 2013 tri listbox
Réponses
3
Affichages
745
Réponses
1
Affichages
402
Réponses
33
Affichages
2 K
  • Question Question
Microsoft 365 Automatisation calcul
Réponses
2
Affichages
727
Réponses
19
Affichages
2 K
Les cookies sont requis pour utiliser ce site. Vous devez les accepter pour continuer à utiliser le site. En savoir plus…