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 :

Chercher dans une feuille le contenu d'une cellule d'une autre feuille à laquelle s'ajoute un string


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Juin 2023
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chargé d'affaire
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2023
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Chercher dans une feuille le contenu d'une cellule d'une autre feuille à laquelle s'ajoute un string
    Bonjour à tous,

    Je cherche à faire une macro a priori pas bien compliquée, mais je bloque.
    Je vous explique le problème.

    J'ai un fichier excel avec 2 feuilles.
    La première contient 2 colonnes : une liste de références, et le poids associé à chaque référence
    Le souci : chaque référence est décomposée en plusieurs lignes (par composant de la référence) puis en une ligne donnant le total.
    Comme ça:
    28076
    28076
    28076
    28076 2,1
    28076 8,5
    28076 7,7
    28076 6
    28076 6,1
    28076 0,5
    28076
    28076 Total 79,5
    28076E
    28076E
    28076E
    28076E 2,1
    28076E 8,5
    28076E 7,7
    28076E 6
    28076E 6,1
    28076E 0,5
    28076E
    28076E Total 79,5
    28077
    28077
    28077
    28077 2,6
    28077 8,5
    28077 2,1
    28077 6
    28077 6,1
    28077 0,5
    28077
    28077 Total 83,7

    Dans la deuxième feuille, j'ai également 2 colonnes. La première est un sous-ensemble de la liste de références de la feuille n°1, et la deuxième le chiffre des ventes.
    Comme cela :
    28076 154
    28077 235

    Notez que la référence 28076E présente dans la feuille 1 n'est pas dans la n°2

    Je souhaite obtenir le poids total des ventes par référence dans la troisième colonne de la feuille n°2, comme cela:
    28076 154 12243 -- 79.5 (poids total ref 28076) x 154 (chiffre des ventes ref 28076 ) =12243
    28077 235 19669.5

    Je n'ai donné un exemple ici que sur 3 références, mais il y en a plusieurs milliers

    J'ai essayé de faire ça avec une macro qui copie la ref de la feuille n°2, puis fait une recherche dans la feuille n°1 avec le contenu du presse-papier auquel il faut ajouter le string 'Total'.
    Mais j'ai l'imppression qu'avec la fonction Find ce n'est pas possible, et mes essais avec la fonction SearchCells échouent lamentablement.
    Il faut dire que mes années de codes sont loin derrière...

    Merci à tous pour votre aide!

  2. #2
    Membre confirmé
    Homme Profil pro
    Auto entrepreneur
    Inscrit en
    Décembre 2021
    Messages
    347
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Auto entrepreneur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2021
    Messages : 347
    Points : 546
    Points
    546
    Par défaut
    Bonjour,

    A tester :
    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
    29
    30
    31
     
    Sub CalculerLePoidsTotaldesVentes()
     
    Dim I As Long, J As Long, DerniereLigne As Long
    Dim AireF1 As Range, AireF2 As Range
     
        With Sheets("Feuil2")
             DerniereLigne = .Cells(.Rows.Count, 1).End(xlUp).Row
             Set AireF2 = .Range(.Cells(2, 1), .Cells(DerniereLigne, 1))
        End With
     
        With Sheets("Feuil1")
             DerniereLigne = .Cells(.Rows.Count, 1).End(xlUp).Row
             Set AireF1 = .Range(.Cells(2, 1), .Cells(DerniereLigne, 1))
        End With
     
        For I = 1 To AireF2.Count
            For J = 1 To AireF1.Count
                If CStr(AireF2(I)) = CStr(AireF1(J)) And InStr(1, AireF1(J).Offset(0, 1), "Total") > 0 Then
                    With AireF2(I).Offset(0, 2)
                        .Value = CDbl(Split(Trim(AireF1(J).Offset(0, 1)), " ")(1)) * AireF2(I).Offset(0, 1)
                        .NumberFormat = "#,##0.00"
                    End With
                End If
            Next J
        Next I
     
        Set AireF1 = Nothing: Set AireF2 = Nothing
     
     
    End Sub

Discussions similaires

  1. Réponses: 1
    Dernier message: 05/12/2016, 22h07
  2. Réponses: 13
    Dernier message: 29/03/2016, 21h39
  3. Réponses: 0
    Dernier message: 24/10/2012, 15h33
  4. [XL-2007] Chercher dans une feuille et supprimer
    Par 0916paps dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 20/10/2010, 22h12
  5. Réponses: 0
    Dernier message: 18/07/2009, 15h59

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