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 :

Utilisation d'un indice dans un Range


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2019
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 15
    Par défaut Utilisation d'un indice dans un Range
    Bonjour,

    Je dois trier un classeur excel selon une colonne, mais ce classeur ne fait malheureusement pas toujours la même taille en termes de ligne.

    J'ai donc setup une macro qui calcule le nombre de lignes de l'excel, appelons l'indice i.

    Le sort fields se fait sur la range "H2:H" & i
    Le sort se fait sur la range "A1:J" & i

    Exemple i = 350 : "H2:H350" et "A1:J350"

    J'ai logiquement créé deux strings : "H2:H" et "A1:J" auxquels je concatène i une fois calculé.
    Sauf que rien n'y fait, en espionnant la valeur de mes strings, au lieu d'avoir par exemple "H2:H350", j'ai "H2:H 350" ce qui fait planter la suite du programme.
    J'ai même essayé de supprimer l'espace créé avec .Trim, mais il semble artificiel et ne se supprime pas.

    Peut-être n'ai-je pas la bonne approche ?

    Merci beaucoup de votre aide, je mets mon code ci-dessous

    Antdec


    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
     
    Sub Tri_prospect()
    '
    ' Tri_prospect Macro
        Dim i As Integer
        i = 1
        While Worksheets(1).Cells(i, 1).Value <> ""
            i = i + 1
        Wend
        Dim interv1, interv2 As String
        interv1 = Application.WorksheetFunction.Trim("H2:H" & Str(i))
        interv2 = Application.WorksheetFunction.Trim("A1:J" & Str(i))
     
        Cells.Select
        ActiveWorkbook.Worksheets(1).Sort.SortFields. _
            Clear
        ActiveWorkbook.Worksheets(1).Sort.SortFields. _
            Add2 Key:=Range(interv1), SortOn:=xlSortOnValues, Order:=xlAscending, _
            DataOption:=xlSortNormal
        With ActiveWorkbook.Worksheets(1).Sort
            .SetRange Range(interv2)
            .Header = xlYes
            .MatchCase = False
            .Orientation = xlTopToBottom
            .SortMethod = xlPinYin
            .Apply
        End With
    End Sub

  2. #2
    Expert confirmé
    Avatar de jurassic pork
    Homme Profil pro
    Bidouilleur
    Inscrit en
    Décembre 2008
    Messages
    4 228
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Bidouilleur
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2008
    Messages : 4 228
    Par défaut
    Hello,
    il faut utiliser CStr et pas Str.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Sub testInteger()
    Dim i As Integer
    For i = 349 To 350
       Debug.Print Str(i)
       Debug.Print CStr(i)
    Next
    End Sub
    donne :
    Ami calmant, J.P

  3. #3
    Expert confirmé
    Homme Profil pro
    Responsable des études
    Inscrit en
    Juillet 2014
    Messages
    2 680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aude (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable des études
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2014
    Messages : 2 680
    Par défaut
    Bonjour,

    Pour ma part je n'ai jamais eu de soucis en utilisant i directement

  4. #4
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2019
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 15
    Par défaut
    Citation Envoyé par jurassic pork Voir le message
    Hello,
    il faut utiliser CStr et pas Str.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Sub testInteger()
    Dim i As Integer
    For i = 349 To 350
       Debug.Print Str(i)
       Debug.Print CStr(i)
    Next
    End Sub
    donne :
    Ami calmant, J.P

    Merci c'est totalement ce qu'il me fallait !

    Au plaisir

    Antdec

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

Discussions similaires

  1. Utilisation d'une variable dans un Range
    Par GregoryGuillaume dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 23/08/2013, 15h49
  2. Réponses: 1
    Dernier message: 11/05/2010, 20h43
  3. [tSampleRow][rangée] Utilisation de variables globales dans tSampleRow
    Par mathieu_r dans le forum Développement de jobs
    Réponses: 1
    Dernier message: 19/02/2010, 12h22
  4. Utiliser une fonction excel dans une macro et proprièté range
    Par bebel9313 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 11/08/2007, 14h25
  5. [VBA-E]Utiliser un indice dans un nom d'objet
    Par Elstak dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 21/06/2006, 16h42

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