problème écriture dans cellule

  • Initiateur de la discussion shp
  • Date de début
S

shp

Guest
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
 

Discussions similaires

Statistiques des forums

Discussions
314 017
Messages
2 104 577
Membres
109 081
dernier inscrit
Vio21