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 :

problème en recopiant une fonction VBA dans les cellules adjacentes


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
    retraité
    Inscrit en
    Août 2023
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 89
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Août 2023
    Messages : 29
    Par défaut problème en recopiant une fonction VBA dans les cellules adjacentes
    Bonjour,
    Après les très bons conseils de USER, jurassic pork et loufab, j'ai une autre demande.
    Le programme suivant ne fonctionne pas pour les couleurs (en le recopiant) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Public Function EssaiGJ(xdate As Range)
        Dim jour As Integer, Mois As Integer, An As Integer
        jour = Day(xdate.Text): Mois = Month(xdate.Text): An = Year(xdate.Text)
            If An + Mois / 100 + jour / 10000 < 1582.1015 Then
                ActiveCell.Font.ColorIndex = 10
                EssaiGJ = "Julien"
            Else
                ActiveCell.Font.ColorIndex = 3
                EssaiGJ = "Grégorien"
            End If
    End Function
    Je pense que cela vient du fait que l'adresse de la cellule active est absolue (elle reste la même en la recopiant). Si oui comment la transformer en adresse relative ?
    Merci
    jp Moniatte

  2. #2
    Rédacteur/Modérateur
    Avatar de loufab
    Homme Profil pro
    Entrepreneur en solutions informatiques viables et fonctionnelles.
    Inscrit en
    Avril 2005
    Messages
    12 137
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Entrepreneur en solutions informatiques viables et fonctionnelles.
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2005
    Messages : 12 137
    Par défaut
    tu as le bouton "Modifier le message" c'est bien aussi.

    oups !!!

    Je ne pense pas que ça puisse marcher en faisant un activecell, utilise la mise en forme conditionnelle c'est fait pour ça.
    Détecter les modifications formulaire Cloud storage et ACCESS
    Classe MELA(CRUD) Opérateur IN et zone de liste Opérateur LIKE
    Visitez mon Blog
    Les questions techniques par MP ne sont pas lues et je ne pratique pas la bactériomancie

  3. #3
    Membre averti
    Homme Profil pro
    retraité
    Inscrit en
    Août 2023
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 89
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Août 2023
    Messages : 29
    Par défaut
    Bonjour,
    Je me suis mal exprimé.
    Je place dans la colonne A des dates des 2 calendriers (grégorien, l'actuel, et julien)
    Exemples : A1 = 23/09/2023 (grégorien), A2 = 5/4/1500 (julien), etc...
    En B1 = EssaiGJ (A1) = Grégorien en rouge
    En B2 = EssaiGJ (A2) = julien en vert, etc...
    Pas de problème.
    Afin d'éviter cette répétition :
    En B1 toujours EssaiGJ(A1); je sélectionne B1 et les cellules en dessous, puis "copier vers le bas"
    Tous les "grégorien" et "julien" seront en rouge.
    Cela est dû au fait que la cellule active reste toujours B1 (par modification du programme son adresse est toujours $B$1)
    Quelle solution ?
    Merci

  4. #4
    Rédacteur/Modérateur
    Avatar de loufab
    Homme Profil pro
    Entrepreneur en solutions informatiques viables et fonctionnelles.
    Inscrit en
    Avril 2005
    Messages
    12 137
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Entrepreneur en solutions informatiques viables et fonctionnelles.
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2005
    Messages : 12 137
    Par défaut
    J'ai bien compris ton problème.

    Je ne vois pas de solution applicable dans la fonction elle-même.

    La mise en forme conditionnelle est là pour ça.
    Détecter les modifications formulaire Cloud storage et ACCESS
    Classe MELA(CRUD) Opérateur IN et zone de liste Opérateur LIKE
    Visitez mon Blog
    Les questions techniques par MP ne sont pas lues et je ne pratique pas la bactériomancie

  5. #5
    Membre averti
    Homme Profil pro
    retraité
    Inscrit en
    Août 2023
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 89
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Août 2023
    Messages : 29
    Par défaut
    Merci

  6. #6
    Membre averti
    Homme Profil pro
    retraité
    Inscrit en
    Août 2023
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 89
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Août 2023
    Messages : 29
    Par défaut La SOLUTION
    Bonjour,
    La solution :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Public Function EssaiGJ(xdate As Range)
        Dim jour As Integer, Mois As Integer, An As Integer, CelluleSource As Range
        Set CelluleSource = Application.Caller
        jour = Day(xdate.Text): Mois = Month(xdate.Text): An = Year(xdate.Text)
            If An + Mois / 100 + jour / 10000 < 1582.1015 Then
                CelluleSource.Font.ColorIndex = 10: EssaiGJ = "Julien"
            Else
                CelluleSource.Font.ColorIndex = 3: EssaiGJ = "Grégorien"
            End If
    End Function
    Grâce à Tiago DA-SILVA d'ATHEOS Ingenierie Strasbourg
    JP Moniatte

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

Discussions similaires

  1. [XL-2007] Appeler Une fonction VBa Dans Excel
    Par stevekho dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 23/08/2010, 14h06
  2. Réponses: 1
    Dernier message: 29/01/2010, 16h38
  3. [XL-2003] Utiliser une fonction VBA dans une cellule
    Par zakuli dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 20/08/2009, 19h23
  4. [SP-2007] Créer une fonction utilisable dans les champs calculés
    Par lolomoss dans le forum SharePoint
    Réponses: 4
    Dernier message: 25/06/2009, 08h49
  5. Intégrer une fonction VBA dans une requête
    Par chelmi95 dans le forum IHM
    Réponses: 1
    Dernier message: 15/09/2008, 18h55

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