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 :

Recherche de mot dans cellule [XL-2003]


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club Avatar de jeff1494
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    105
    Détails du profil
    Informations personnelles :
    Âge : 69
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 105
    Points : 53
    Points
    53
    Par défaut Recherche de mot dans cellule
    Bonsoir à tous;
    Je reviens vers vous car j'aimerais pouvoir modifier le code suivant :
    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
     
    Private Sub CommandButton1_Click()
    Dim lastlig As Long, i As Long, j As Long
    Dim mot As String
    Dim c As Range
    Dim tablo() As String
     
    lastlig = Cells(Columns(1).Cells.Count, 1).End(xlUp).Row
    mot = InputBox("Mot cherché")
    mot = "*" & Ucase(mot) & "*"
    ReDim tablo(1)
    j = 0
    Range("B2:B" & lastlig).Interior.ColorIndex = xlNone
    For Each c In Range("B2:B" & lastlig)  'à adapter
        If Ucase(c.Value) Like mot Then
            tablo(j) = c.Value
            c.Interior.ColorIndex = 4
            ReDim Preserve tablo(UBound(tablo) + 1)
            j = j + 1
        End If
    Next c
    Sheets("Feuil2").Columns("A:A").ClearContents
    For i = 0 To UBound(tablo)
        Sheets("Feuil2").Range("A" & i + 1) = tablo(i)
    Next i
    End Sub
    Ce code copie une cellule sur une feuille2 si elle contient un certain mot.
    Moi j'aimerais copier la ligne entière sur la feuille 2 en commençant en ligne 2.
    Je ne suis pas du tout familier avec les tableaux. Alors siquelqu'un pouvait m'aider.
    D'avance merci pour votre aide.
    Cordialement.

  2. #2
    Expert éminent sénior Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Points : 31 877
    Points
    31 877
    Par défaut
    la réponse dans l'autre post (que je vais supprimer)
    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
    Private Sub CommandButton1_Click()
    Dim lastlig As Long, i As Long, j As Long
    Dim mot As String
    Dim c As Range
    Dim tablo() As String
     
    lastlig = Cells(Columns(1).Cells.Count, 1).End(xlUp).Row
    mot = InputBox("Mot cherché")
    mot = "*" & UCase(mot) & "*"
    ReDim tablo(1)
    j = 0
    Range("B2:B" & lastlig).Interior.ColorIndex = xlNone
    For Each c In Range("B2:B" & lastlig)  'à adapter
        If UCase(c.Value) Like mot Then
            tablo(j) = c.Row
            c.Interior.ColorIndex = 4
            j = j + 1
        End If
    Next c
    Sheets("Feuil2").Columns("A:A").ClearContents
    For i = 0 To UBound(tablo)
        Rows(tablo(i)).Copy Sheets("Feuil2").Range("A" & i + 1)
    Next i
    End Sub
    en prend le n° de la ligne dans tablo
    et on copie la ligne entière dans feuil2
    Cordialement.
    J'utilise toujours le point comme séparateur décimal dans mes tests.

  3. #3
    Membre confirmé
    Inscrit en
    Janvier 2008
    Messages
    467
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 467
    Points : 493
    Points
    493
    Par défaut
    Bonsoir
    sans tableau
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Private Sub CommandButton1_Click()
        Dim lastlig As Long, mot As String, c As Range
        lastlig = Cells(Columns(1).Cells.Count, 1).End(xlUp).Row
                mot = InputBox("Mot cherché")
                mot = "*" & UCase(mot) & "*"
    Range("B2:B" & lastlig).Interior.ColorIndex = xlNone
    For Each c In Range("B2:B" & lastlig)
        If UCase(c.Value) Like mot Then
            Feuil2.Range("B65536").End(xlUp)(2).Resize(1, 10).Value = c.Resize(1, 10).Value ' ou 10 le nombre de cellules à copiées
            c.Interior.ColorIndex = 4
        End If
    Next c
    End Sub
    Bonne nuit à vous deux

  4. #4
    Expert éminent sénior Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Points : 31 877
    Points
    31 877
    Par défaut
    à force de changer dans un précédent post, on arrive à des "absurdités" involontaires
    ou ceci
    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
    Private Sub CommandButton1_Click()
    Dim lastlig As Long, j As Long
    Dim mot As String
    Dim c As Range
     
    lastlig = Cells(Columns(1).Cells.Count, 1).End(xlUp).Row
    mot = InputBox("Mot cherché")
    mot = "*" & UCase(mot) & "*"
    j = 2
    Sheets("Feuil2").Cells.ClearContents
     
    Range("B2:B" & lastlig).Interior.ColorIndex = xlNone
    For Each c In Range("B2:B" & lastlig)  'à adapter
        If UCase(c.Value) Like mot Then
            Rows(c.Row).Copy Sheets("Feuil2").Range("A" & j)
            c.Interior.ColorIndex = 4
            j = j + 1
        End If
    Next c
    End Sub
    Cordialement.
    J'utilise toujours le point comme séparateur décimal dans mes tests.

  5. #5
    Membre du Club Avatar de jeff1494
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    105
    Détails du profil
    Informations personnelles :
    Âge : 69
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 105
    Points : 53
    Points
    53
    Par défaut
    Bonjour Mercatog, Abel_H, et le forum;
    Merci à vous deux pour vos solutions. C'est parfait.
    Bonne journée à tous.
    Cordialement.

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

Discussions similaires

  1. Rechercher un mot dans un texte
    Par BernardT dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 13/12/2005, 08h55
  2. [Regex]Recherche de mots dans une chaîne
    Par lionel69 dans le forum Collection et Stream
    Réponses: 7
    Dernier message: 17/11/2005, 18h20
  3. rechercher un mot dans un titre
    Par MANU_2 dans le forum Requêtes
    Réponses: 3
    Dernier message: 09/11/2005, 12h02
  4. Recherche de mot dans un CRichEdit
    Par jawad91 dans le forum MFC
    Réponses: 1
    Dernier message: 28/04/2005, 15h36
  5. [TP]Recherche de mots dans un Doc.
    Par Loceka dans le forum Turbo Pascal
    Réponses: 8
    Dernier message: 04/10/2004, 19h04

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