Les Allergies
Alimentaires
Posez votre question Signaler

[VBA Excel] Ecrire dans des cellules

shp 19Messages postés 12 avril 2005Date d'inscription - Dernière réponse le 8 juil. 2010 à 17:49
Bonjour,

Je travaille sous Windows 2000 et Excel 2000.

J’utilise fréquemment les formules sous Excel. J’ai étudié pas mal de langages de programmation mais pas le VBA.

Je fais un mini générateur de planning sous excel. Le but est de positionner une action dans le planning du formateur si celui-ci est libre, sinon d’afficher une boite de message et d’effacer l’action tapée.
J’ai tapé la formule : =SI(S78="";S7;oqp()) dans laquelle la fonction oqp() écrite en VBA(langage de programmation que je découvre).

Function oqp() As String
' Affiche une boîte de message ;
' Efface le contenu de la cellule active
' Affecte la chîne cc à la cellule S9

Dim Msg, Style, Title, Help, Ctxt, Response, MyString, cel_edt
Msg = "F oqp"
Style = vbOKOnly + vbCritical
Title = "Occupé "
Help = "DEMO.HLP"
Ctxt = 1000

Response = MsgBox(Msg, Style, Title, Help, Ctxt)
ActiveCell.Value = ""
Worksheets("essais").Range("S9").Value = "cc"
Range("S7").Clear
oqp = "cc"

End Function


Cette fonction est appelée dans la cellule S41 via la formule : =SI(S78="";S7;oqp())

Ce que je trouve étrange est que lorsque je tape une chaîne dans S7, la boîte de message apparaît mais
· le contenu de S7 ne s’efface pas ;
· cc n’est pas écrit dans S9 ;
· dans S41, je vois apparaître #VALEUR!
Alors que lorsque je clique sur le bouton exécuter de l’éditeur vba : cc s’écrit dans S9 mais par contre les autres points restent inchangés.

Bien sûr ceci n’est qu’un exemple pour vérifier que la fonction oqp fonctionne.
Les lignes qui sont d’après moi la cause de ces erreurs sont :
ActiveCell.Value = ""
Worksheets("essais").Range("S9").Value = "cc"
Je me demande s’ il ne manque pas un « include » pour les entrée /sortie mais je n’ai rien trouvé dans l’aide , ni sur internet.


Je vous remercie d’avance de votre aide.

Shp
Lire la suite 

[VBA Excel] Ecrire dans des cellules »

4 réponses
Réponse
+1
moins plus
bonjour

Les lignes qui sont d’après moi la cause de ces erreurs sont :
ActiveCell.Value = ""
Worksheets("essais").Range("S9").Value = "cc"


à mon avis ce n'est pas là qu'il faut chercher.

ta fonction ne correspond pas au but que tu lui assigne.

il serait plus judicieux de tester et de controler les modifs.

shp - 13 avril 2005 à 10:12
Bonjour,

Je mets ce que les instructions sont sensées faire (pour moi, novice en VBA !).

‘mettre la chaîne " " dans la cellule active
ActiveCell.Value = " "

‘affecter la chaîne cc dans la cellule S9
Worksheets("essais").Range("S9").Value = "cc"

Si tu vois une erreur de traduction dans ces instructions, dis-moi laquelle car, à mon avis, c’est la source de mon problème.

Merci de ton aide.
Ajouter un commentaire
Réponse
+0
moins plus
bonjour

Efface le contenu de la cellule active

pour cela c'est : ActiveCell.Value = ""
car si tu mets un espace la cellule ne sera pas vide

Par contre, je n'ai peut-être pas compris ton problème
mais à mon avis ta fonction n'est pas adaptée
et je pense que tu aurais plus facilement la solution
avec une procédure :

Private Sub Worksheet_Change(ByVal celmod As Range)
if ...

End Sub

Ajouter un commentaire
Réponse
+0
moins plus
Bon même si ce post est assez vieux, je vais tenter de répondre à la question car j'ai eu un problème similaire.

En fait, il est impossible de modifier une cellule à partir de fonctions appelées dans une autre cellule. Bref, si c'est possible, c'est vraiment complexe et désagréable à programmer.

Excel a une protection qui assure que les formules inscrites dans les cellules peuvent seulement modifier leurs propres résultats. Par contre, si tu roule la fonction dans VBA directement via un

Public sub

FonctionTest( toto1, toto2)

End sub

Tes modifications vont se faire. C'est triste mais il faut programmer toutes les cellules une à la fois alors dans le cas présent, la cellule à modifier dans OCP devra avoir sa propre fonction qui pourra modifier la valeur de sa cellule propre.

En gros, si la fonction dans A1 essaie de modifier B1, ça marche pas!

A+
Ajouter un commentaire
Ce document intitulé « [VBA Excel] Ecrire dans des cellules » issu de CommentCaMarche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.
Dossier à la une
Passage au tout numérique : quel coût pour les particuliers ?