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 :

[VBA] Formule avec variables


Sujet :

Macros et VBA Excel

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Février 2008
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 3
    Points : 2
    Points
    2
    Par défaut [VBA] Formule avec variables
    Bonjour a tout le monde,

    Je fais normalement du code pour VBA-CATIA et maintenant j'en ai besoin d'excel et il y a des choses qui m'echappent...

    J'ai une macro laquelle crée une nouvelle feuille chaque mois, et j'aimerais ajouter une formule dans une cellule, laquelle pointe vers la nouvelle feuille (si elle existe).

    Tout marche sauf la formule, car je n'arrive pas a mettre une variable dans ma formule. Si je fais :
    (osheet est la variable du nom de ma nouvelle feuille)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Range("F21").Select
        ActiveCell.FormulaR1C1 = "=" & osheet & "!F1"
    ca ne marche pas, et si je le fais avec :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    activecell.value = "=" & osheet & "!F1"
    ca ne marche pas non plus, car il m'ajoute les petits ' ' aux mauvais endroits et excel prends la formule comme du text quelconque... au lieu de prendre le bon nom pour la feuille...

    J'ai lu pas mal des discussions sur ce type de chose mais je ne comprends rien!!! il y a tout un nombre des formules diferentes et je n'arrive pas a le faire marcher...

    Merci d'avance

    luis

  2. #2
    Expert éminent
    Avatar de Qwazerty
    Homme Profil pro
    La très haute tension :D
    Inscrit en
    Avril 2002
    Messages
    3 906
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : La très haute tension :D
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2002
    Messages : 3 906
    Points : 8 539
    Points
    8 539
    Par défaut
    SAlut et bienvenu
    Il faut faire comme cela

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Sub Test()
    Dim OSheet As String
    OSheet = "Feuil1"
    Sheets("feuil2").Range("A1").FormulaLocal = "=" & OSheet & "!A1"
     
    End Sub
    FormulaR1C1 c'est pour une formule a référence relative (décalage ligne, colonne)

    A++
    Qwaz

    MagicQwaz := Harry Potter la baguette en moins
    Le monde dans lequel on vit
    Ma page perso DVP
    Dernier et Seul Tutoriel : VBA & Internet Explorer
    Dernière contribution : Lien Tableau Structuré et UserForm
    L'utilisation de l’éditeur de message

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Février 2008
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    magnifique, merci qwazerty, mais encore une complication...
    en fait j'avais quasiment tout comme tu me l'as décrit sauf le formulaR1C1... maintenant mon prob est encore plus subtil...

    Le nom de mes feuilles est integre par 2 chiffres, c'est-à-dire:
    1-2008
    2-2008
    3-2008
    etc, etc, etc...

    catia prends ma variable osheet sans prob, mais au moment de faire tourner la macro, la formule me donne :

    4-'2008'!F1

    au lieu de

    '4-2008'!F1

    et ca plante....

    des idées???

  4. #4
    Expert éminent
    Avatar de Qwazerty
    Homme Profil pro
    La très haute tension :D
    Inscrit en
    Avril 2002
    Messages
    3 906
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : La très haute tension :D
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2002
    Messages : 3 906
    Points : 8 539
    Points
    8 539
    Par défaut
    Re

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Sub Test()
    Dim OSheet As String
    OSheet = "4-2008"
    Sheets("feuil2").Range("A1").FormulaLocal = "='" & OSheet & "'!A1"
     
    End Sub
    Le plus simple lorsque tu es confronté a un tel problème c'est d'enregistrer une macro, tu aura ainsi la syntaxe partiel ou complète de ce que tu souhaite faire

    Menu -> Outils -> Macro -> Nouvelle macro
    Et la tu rempli tes cellules
    Ensuite tu vas voir dans le Module ou tu as mis la macro et tu regardes le code généré par excel

    A++
    Qwaz

    MagicQwaz := Harry Potter la baguette en moins
    Le monde dans lequel on vit
    Ma page perso DVP
    Dernier et Seul Tutoriel : VBA & Internet Explorer
    Dernière contribution : Lien Tableau Structuré et UserForm
    L'utilisation de l’éditeur de message

  5. #5
    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
    Bonjour
    et si tu insert directement ta formule dans la cellule F1 par macro sans reféré à la cellule de la feuille présédente..?
    exemple à tester
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ActiveSheet.Range("F21").FormulaLocal = "=SI(A1>5" & ";" & "si_vrai" & ";" & "si_faux" & ")" ' à adapter
    Abed_H

  6. #6
    Membre confirmé
    Avatar de Bigalo
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    445
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Décembre 2007
    Messages : 445
    Points : 563
    Points
    563
    Par défaut
    Bonsoir,

    Comment initialises-tu osheet ?
    Michel Gaboly
    Développeur Excel et VBA


    Pas de question technique par MP, je n’y répondrai pas, utilisez le forum - Merci
    Pensez à ajouter le tag

  7. #7
    Candidat au Club
    Profil pro
    Inscrit en
    Février 2008
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 3
    Points : 2
    Points
    2
    Par défaut
    wow, beaucoup de réponses... merci merci merci...
    en fait ça finalement marché, il me fallait seulement faire le ' avant et aprés du nom de la variable... style
    qwazerty, j'avais fait l'enregistrement de la macro, et comme ça n'a pas marché j'ai commencé a essayer tout ce que je trouvais dans le forum, c'est pour ça que j'ai fini avec une fonction qui n'allait pas et j'ai finalement du demander comment faire...

    abed, je ne peux pas juste inserer la formule, car les données changent chaque mois. Pour faire ça la macro va chercher un fichier txt, l'importe dans une nouvelle feuille chaque mois et après vienne la mettre a jour....

    Bigalo, mon osheet est initialisé comme ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
      oSheet = (oMonth & "-" & oYear)
        oSheetp = ((oMonth - 1) & "-" & oYear)
        On Error GoTo Fichenon
        Sheets(oSheet).Select
        Range("A1").Select
        ActiveSheet.Paste
        GoTo cont
     
    Fichenon:
        ActiveWorkbook.Sheets.Add after:=Sheets(oSheetp), Type:=xlWorksheet
        ActiveSheet.Name = oSheet
        oIndic = 1
    fin bref, la macro marche maintenant, merci bcp pour tous les commentaires

    luis

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

Discussions similaires

  1. [Toutes versions] Insertion formule avec variable dans VBA
    Par Suomiland dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 24/06/2015, 07h30
  2. [VBA] formule avec variable
    Par munity dans le forum SDK
    Réponses: 8
    Dernier message: 28/09/2009, 12h22
  3. probleme requete vba access avec variables
    Par alexkickstand dans le forum VBA Access
    Réponses: 9
    Dernier message: 11/09/2007, 21h19
  4. écriture d'une formule avec "variable"
    Par stephane31 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 31/08/2007, 16h48
  5. [SQL & VBA] Requête avec Variable
    Par Altrensa dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 18/07/2007, 14h31

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