[Basic] Excel et une simple boucle For

Résolu/Fermé
Ralt - 19 nov. 2008 à 10:53
Bidouilleu_R Messages postés 1181 Date d'inscription mardi 27 mai 2008 Statut Membre Dernière intervention 12 juillet 2012 - 20 nov. 2008 à 11:50
Bonjour,

J'ai un fichier Excel rempli de nombres. Je souhaiterais faire en sorte que tous les nombres prennent un ajout de 15% (en restant dans la même case).

Voici le code que j'ai utilisé :

Sub Main
Dim i As Integer
For i=3 to 52
Range("B"&i).Value=Range("B"&i).Value*1.15
Next i
End Sub

Il me dit "Erreur d'exécution BASIC. Sous-procédure ou procédure de fonction non définie". Je ne vois pas ce que je n'ai pas défini, puisque la seule variable utilisée est i, que je déclare.

Si vous avez une meilleure solution, n'hésitez pas!

Cordialement,
Ralt.
A voir également:

6 réponses

wilfried_42 Messages postés 907 Date d'inscription mardi 19 août 2008 Statut Contributeur Dernière intervention 8 décembre 2009 240
19 nov. 2008 à 11:00
Bonjour

ne voyant pas d'erreur j'ai testé ta boucle elle fonctionne parfaitement
aurais tu une autre procédure du même nom ?? dans un module ?, dans une macro complémentaire ?

personnellement, je ne nomme jamais une procédure main, c'est un mot clef dans certains langages

dans l'exemple que tu as donné, il maque () apres main, mais l'éditeur vba d'excel les mettant automatiquement, ca doit venir d'une erreur de recopie
0
Bonjour,

J'ai oublié de préciser que j'utilisais OpenOffice.org Calc 3.0.4. Normalement, le BASIC devrait être pris en charge comme sur Excel, donc ça ne devrait pas poser de problème. J'ai tenté de mettre Sub Test() à la place (les parenthèses ne sont pas rajoutées automatiquement), mais rien n'a changé, même erreur. Il sélectionne la ligne "Range("B"&i).Value=Range("B"&i).Value*1.15", et me sort l'erreur écrite dans le premier post.

Je pense que je vais faire un test avec Microsoft Excel et vous donner un retour.

Cordialement,
Ralt.

P.S. : c'est la seule macro que j'ai.
0
wilfried_42 Messages postés 907 Date d'inscription mardi 19 août 2008 Statut Contributeur Dernière intervention 8 décembre 2009 240
19 nov. 2008 à 11:09
re:

j'ai testé sur excel ca marche, maintenant OOO, j'ai bannis
0
Re-bonjour,

Bon eh bien, après essai sur Excel, ça marche.

OpenOffice.org Calc 3.0.4 supporte donc encore mal le BASIC.

Merci pour votre aide!

Cordialement,
Ralt.
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
Bidouilleu_R Messages postés 1181 Date d'inscription mardi 27 mai 2008 Statut Membre Dernière intervention 12 juillet 2012 277
20 nov. 2008 à 10:25
openoffice "ne supporte pas mal" le basic.

mais l'objet Range n'existe pas sous openoffice.

je reconnais que cela change de VBA
0
Bidouilleu_R Messages postés 1181 Date d'inscription mardi 27 mai 2008 Statut Membre Dernière intervention 12 juillet 2012 277
20 nov. 2008 à 11:50
' je viens compléter mon argumentation
' précédente
' deux étapes dans openoffice
' de préférence plaer dans le module Main les appels de sous programmes
' comme je l'ai fait ci-dessous

Sub Main
ModifieListe ' ma procédure
End Sub
'
Sub ModifieListe
REM Déclarations API obligatoires les objets document feuilles, cellules
Dim oDocument As Object, oSheet As Object, oCell As Object
dim I as integer
Dim MaValeur as double
oDocument = ThisComponent
oSheet=oDocument.Sheets.getByName ("Feuille1" )
'
for i=3 to 17
oCell = oSheet.getCellByPosition (0,I )
MaValeur=oCell.value* 1.2
oCell.setvalue(MaValeur)
next I

rem volontairement je suis parti de A3 vers A20
rem MaValeur est une variable double (attention majuscule minuscule important)




End Sub



Cet un exemple vite fait
mais qui peut aider
0