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 :

Changement de format d'une plage de cellules sous conditions


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Août 2019
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Août 2019
    Messages : 3
    Par défaut Changement de format d'une plage de cellules sous conditions
    Bonjour à tous,

    Je débute sur VBA et aurais bien besoin de votre aide,

    Je cherche en effet à réaliser une boucle me permettant de réaliser la chose suivante :

    Dans la colonne B je dispose d'une suite de montant, or parfois le format ne permet pas de traiter la donnée,

    Pour exemple dans le fichier : en B34, " 175-" que je souhaiterai à l'aide d'une macro retraiter afin d'obtenir "-175"

    Les données positives n'ont pas besoin d'etre retraitées,

    Merci à l'ame charitable qui me donnera un coup de main !

    Bonne journée
    Fichiers attachés Fichiers attachés

  2. #2
    Membre Expert Avatar de Thautheme
    Homme Profil pro
    salarié
    Inscrit en
    Août 2014
    Messages
    1 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : salarié

    Informations forums :
    Inscription : Août 2014
    Messages : 1 373
    Par défaut
    Oi Zaziho, bonjour le forum,

    Essaie comme ca :

    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
    Sub Macro1()
    Dim O As Worksheet 'déclare la variable O (Onglet)
    Dim TV As Variant 'déclare la variable TV (Tableau des Valeurs)
    Dim I As inrteger 'déclare la variable I (Incrément)
     
    Set O = Worksheets("Ex Developpez.net ") 'définit l'onglet O (à adapter à ton cas)
    TV = O.Range("A1").CurrentRegion 'définit le tableau des valeurs TV
    For I = 1 To UBound(TV, 1) 'boucle sur toutes les lignes I du tableau des valeurs TV
        TV(I, 2) = Trim(TV(I, 2)) 'supprime les espaces avant et après de la donnée ligne I colonne 2 de la boucle
        'si le premier caractère à droite (= le dernier caractère) est un moins "-",
        'la donnée ligne I colonne 2 de la boucle devient négative et le dernier caractère est supprimé
        If Right(TV(I, 2), 1) = "-" Then TV(I, 2) = -Left(TV(I, 2), Len(TV(I, 2)) - 1)
    Next I 'prochaine ligne de la ,boucle
    O.Range("A1").Resize(UBound(TV, 1), 2).Value = TV 'renvoie le tableau TL dans A1 redimensionnée
    End Sub

  3. #3
    Candidat au Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Août 2019
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Août 2019
    Messages : 3
    Par défaut Adaptation colonne X
    Bonjour Thauthème,

    Merci beaucoup pour ton aide, et désolé pour le temps de réponse (week end prolongé oblige)

    En revanche, comme l'exemple était bidon (bien entendu), je cherche à adapter la macro pour la colonne X et non la colonne B, hors les données de la colonne B sont copié dans la colonne X,

    Est ce que quelqu'un pourrait m'indiquer comment l'adapter ?

    Voila comment j'ai adapté :

    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
    Sub Macro1()
    Dim O As Worksheet 'déclare la variable O (Onglet)
    Dim TV As Variant 'déclare la variable TV (Tableau des Valeurs)
    Dim I As Integer 'déclare la variable I (Incrément)
     
    Set O = Worksheets("Ex Developpez.net ") 'définit l'onglet O (à adapter à ton cas)
    TV = O.Range("X1").CurrentRegion 'définit le tableau des valeurs TV
    For I = 1 To UBound(TV, 1) 'boucle sur toutes les lignes I du tableau des valeurs TV
        TV(I, 24) = Trim(TV(I, 24)) 'supprime les espaces avant et après de la donnée ligne I colonne 2 de la boucle
        'si le premier caractère à droite (= le dernier caractère) est un moins "-",
        'la donnée ligne I colonne 2 de la boucle devient négative et le dernier caractère est supprimé
        If Right(TV(I, 24), 1) = "-" Then TV(I, 24) = -Left(TV(I, 24), Len(TV(I, 24)) - 1)
    Next I 'prochaine ligne de la ,boucle
    O.Range("X1").Resize(UBound(TV, 1), 24).Value = TV 'renvoie le tableau TL dans A1 redimensionnée
    End Sub
    Quelles sont les erreurs please ?

    Merci beaucoup !

  4. #4
    Expert confirmé
    Homme Profil pro
    Responsable des études
    Inscrit en
    Juillet 2014
    Messages
    2 683
    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 683
    Par défaut
    Bonjour,

    N'oublie pas les balises code (bouton #) ça rend le message beaucoup plus lisible

    Tu dois laisser A1 à la dernière ligne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    O.Range("A1").Resize(UBound(TV, 1), 24).Value = TV 'renvoie le tableau TL dans A1 redimensionnée
    Et ce serait mieux de laisser sur cette ligne aussi:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TV = O.Range("A1").CurrentRegion 'définit le tableau des valeurs TV

  5. #5
    Candidat au Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Août 2019
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Août 2019
    Messages : 3
    Par défaut Remerciements
    Super, Merci beaucoup !

  6. #6
    Membre Expert Avatar de Thautheme
    Homme Profil pro
    salarié
    Inscrit en
    Août 2014
    Messages
    1 373
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : salarié

    Informations forums :
    Inscription : Août 2014
    Messages : 1 373
    Par défaut
    Bonjour le fil, bonjour le forum,

    Je te remercie aussi Halaster d'avoir pris le relai.

Discussions similaires

  1. [XL-2019] Remplir une plage de cellule sous 2 conditions
    Par gregory.d dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 30/07/2019, 16h51
  2. [XL-2013] Verrouiller une plage de cellules avec condition
    Par jfmeehan dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 29/12/2015, 01h57
  3. Réponses: 10
    Dernier message: 01/07/2013, 16h06
  4. Réponses: 6
    Dernier message: 23/11/2012, 10h06
  5. Conversion du format d'une plage de cellules Excel
    Par tarbala dans le forum API, COM et SDKs
    Réponses: 0
    Dernier message: 13/06/2009, 00h47

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