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 :

Remplacer du texte dans un onglet [XL-2010]


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Novembre 2019
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Suisse

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2019
    Messages : 13
    Points : 19
    Points
    19
    Par défaut Remplacer du texte dans un onglet
    Hello
    Suite à une très grossière erreur de modification de ma part, j'ai une très grosse quantité de cellules avec des références erronées d'un autre classeur

    Je voudrais remplacer cette chaîne de caractères :
    ='D:\Joomla\Auction-autos\Admin\[Auto.xlsm]Générale
    Par :
    =Générale!

    J'ai essayé avec ce code mais comme je suis débutant je ne vois pas ou est l'erreur ou si ce code est utilisable tel quel
    Il y a erreur sur cellule.Value

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Sub Remplace_Texte()
    For Each cellule In Range("A1:E1000")
        cellule.Replace What:="='D:\Joomla\Auction-autos\Admin\[Auto.xlsm]Générale'", Replacement:="=Générale", LookAt:=xlPart, SearchOrder:=xlByRows, MatchCase:=False
        cellule.Value = Str(cellule.Value)
    Next cellule
    End Sub
    Merci d'avance pour l'aide

  2. #2
    Membre extrêmement actif
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 82
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Points : 12 422
    Points
    12 422
    Par défaut
    Bonjour
    Sans préjudice de l'intérêt à utiliser à toute la plage concernée la méthode Range.Replace, plutôt qu'une boucle pour remplacer chaque cellule (mais c'est une autre affaire et je me contente donc de mettre en exergue la cause de l'erreur constatée)
    La fonction Str ne peut que recevoir un paramètre numérique et non de type String
    Je n'accepte pas de demande d' "amitié" individuelle. Tout développeur est pour moi un ami.
    Je n'ouvre AUCUN classeur tiers (avec ou sans macro ******). Ne m'en proposez donc pas .

    ****** : Non, non ... un classeur .xlsx ne "peut" par exemple et entre autres pas contenir un activex (de surcroît invisible) , "bien sûr" ...

    Il est illusoire de penser que l'on saurait exprimer valablement et précisément en un langage (rigide) de développement ce que l'on peine à exprimer dans le langage naturel, bien plus souple.

  3. #3
    Membre à l'essai
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Novembre 2019
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Suisse

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2019
    Messages : 13
    Points : 19
    Points
    19
    Par défaut
    Merci pour la réponse qui ne m'aide pas vraiment. Pas grave je le ferais manuellement, punition pour ma grossière erreur et surtout de n'avoir pas fait une sauvegarde dudit fichier avant

  4. #4
    Membre à l'essai
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Novembre 2019
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Suisse

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2019
    Messages : 13
    Points : 19
    Points
    19
    Par défaut
    ... et surtout quand c'est noté DEBUTANT
    Il y a d'autres forums avec des gens compétents et bien plus conciliants avec ceux qui essayent de faire quelque chose
    A bientôt 58 balets, j'essaie d'aider une asso et ce genre de réponse me .......

    Bilan sur 2 questions :
    - 1 = aidé mais remis en place et sujet résolu, merci
    - 2 = mis au rebus direct

    .... par la même personne

    Je mets Sujet RESOLU alors que pas du tout, mais bon je cherche ailleurs, je débute

  5. #5
    Membre extrêmement actif
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 82
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Points : 12 422
    Points
    12 422
    Par défaut
    Tu me vois désolé, mais je pensais avoir été clair :
    La fonction Str ne peut que recevoir un paramètre numérique et non de type String
    ceci :
    est compréhensible et retourne "34" (conversion du numérique 34 en la chaîne de caractères "34")
    mais cela
    n"est pas compréhensible et ne peut que retourner un message d'erreur puisqu'incompatibilité de type, "abcd" étant une chaîne de caractères (de type string, donc) et non un numérique.

    Il semble par ailleurs que tu souhaites modifier en fait des formules et non les valeurs présentes dans une plage de données.
    Si tel est bien le cas, il te faut le préciser en précisant la propriété (Formula) à modifier, selon la syntaxe (exemple) qui suit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    cellule.formula = replace(cellule.formula, "ancien texte", "nouveau texte")
    Note bien qu'est ici alors utilisée la fonction Replace et non la méthode Range.Replace

    Il est enfin vraisemblable que ces opérations, à ne faire en outre qu'une fois, ne nécessitent pas l'utilisation de VBA. Mais tes précisions ne permettent pas à ce stade d'en parler de manière plus précise.
    Je n'accepte pas de demande d' "amitié" individuelle. Tout développeur est pour moi un ami.
    Je n'ouvre AUCUN classeur tiers (avec ou sans macro ******). Ne m'en proposez donc pas .

    ****** : Non, non ... un classeur .xlsx ne "peut" par exemple et entre autres pas contenir un activex (de surcroît invisible) , "bien sûr" ...

    Il est illusoire de penser que l'on saurait exprimer valablement et précisément en un langage (rigide) de développement ce que l'on peine à exprimer dans le langage naturel, bien plus souple.

  6. #6
    Responsable
    Office & Excel


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 122
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 122
    Points : 55 926
    Points
    55 926
    Billets dans le blog
    131
    Par défaut
    Salut.

    Avant de le faire en VBA, peut-être peux-tu le faire en Excel, simplement avec l'outil de remplacement (CTRL+H).

    Si tu veux le faire en VBA, tu peux utiliser la méthode Replace d'un objet Range, comme tu l'as fait, et la ligne cellule.Value = Str(cellule.Value) n'est alors pas nécessaire.
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

  7. #7
    Membre à l'essai
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Novembre 2019
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Suisse

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2019
    Messages : 13
    Points : 19
    Points
    19
    Par défaut
    Merci à vous deux !
    La méthode Ctrl+H à mon niveau a été bien plus facile à "mettre en place"
    Fonctionne parfaitement, une fonctionnalité trop simple pour que j'y aie pensé probablement

    env. 2000 remplacements effectués ! top et sans prise de tête de ma part
    Merci Pierre

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

Discussions similaires

  1. Remplacement de texte dans un fichier
    Par horec dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 29/05/2008, 10h25
  2. Programme de remplacement de texte dans des fichiers
    Par Invité4 dans le forum Linux
    Réponses: 13
    Dernier message: 12/11/2006, 16h06
  3. Remplacer un texte dans une cellule Excel à partir d'un point donné
    Par tonyC dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 28/04/2006, 19h05
  4. remplacer du texte dans un tableau généré
    Par jcaruana dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 08/02/2006, 16h36
  5. [langage] Remplacer du texte dans un fichier
    Par Michaël dans le forum Langage
    Réponses: 9
    Dernier message: 11/03/2005, 15h19

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