Excel/ VB remplir automatiquement les cellules

Résolu/Fermé
tsangeps Messages postés 7 Date d'inscription mardi 26 février 2013 Statut Membre Dernière intervention 27 février 2013 - Modifié par tsangeps le 26/02/2013 à 15:54
ccm81 Messages postés 10851 Date d'inscription lundi 18 octobre 2010 Statut Membre Dernière intervention 16 avril 2024 - 27 févr. 2013 à 10:46
Bonjour,

Je fais appel à vous aujourd'hui;
je travaille sur une extraction des données sur une base de travaux (pas très personalisable)
j'obtiens donc un tableur qui a encore besoin de traitement et manuellement cela me prend beaucoup de temps. (plusieurs milliers de lignes)

aa bb cc dd
AA
bb
cc
dd
cc1
dd1

BB
bb1
cc2
dd2
cc3
dd3

CC


J'aimerai donc copier le AA dans les cellules vides qui la suivent jusqu'à BB
et copier BB ainsi de suite
De même pour les autres colonnes.
Et arriver au résultat suivant :

aa bb cc dd
AA
AA bb
AA bb cc
AA bb cc dd
AA bb cc1 dd
AA bb cc1 dd1
AA bb cc1 dd1
BB bb cc1 dd1
BB bb1 cc1 dd1
BB bb1 cc2 dd1
BB bb1 cc2 dd2
BB bb1 cc3 dd2
BB bb1 cc3 dd3
BB bb1 cc3 dd3
CC bb1 cc3 dd3

Merci de votre aide


A voir également:

5 réponses

ccm81 Messages postés 10851 Date d'inscription lundi 18 octobre 2010 Statut Membre Dernière intervention 16 avril 2024 2 404
27 févr. 2013 à 07:45
une autre solution plus rapide (0.38 s pour 25000 lignes)

Public Sub Remplir()
Dim lifin As Long, cofin As Long, li As Long, co As Long, plage As Range
Dim t
Dim d As Single
d = Timer
Application.ScreenUpdating = False
With Sheets(NF)
  cofin = .Cells.Find("*", , , , xlByColumns, xlPrevious).Column
  For co = codeb To cofin
    lifin = .Cells(Rows.Count, co).End(xlUp).Row
    Set plage = .Range(.Cells(lideb, co), .Cells(lifin, co))
    t = Application.Transpose(plage)
    For li = 1 To UBound(t) - 1
      If t(li + 1) = "" Then t(li + 1) = t(li)
    Next li
    plage = Application.Transpose(t)
  Next co
End With
Application.ScreenUpdating = True
MsgBox (Timer - d & " s")
End Sub

bonne journée
1
ccm81 Messages postés 10851 Date d'inscription lundi 18 octobre 2010 Statut Membre Dernière intervention 16 avril 2024 2 404
26 févr. 2013 à 16:06
Bonjour

peux tu envoyer une partie de ton fichier au format excel 2003 sur cjoint.com et joindre le lien obtenu à ton prochain message
n'oublies pas d'y ajouter quelques explications (ce que tu veux obtenir, à partir de quoi, mettre un exemple ...)

bonne suite
0
tsangeps Messages postés 7 Date d'inscription mardi 26 février 2013 Statut Membre Dernière intervention 27 février 2013
26 févr. 2013 à 16:33
Donc voici un lien vers un exemple du tableur extrait de la base

https://www.cjoint.com/?CBAqDcmYIbP

et j'aimerai avoir un résultat comme ci

https://www.cjoint.com/?CBAqGfcvA8n

Je m'explique un peu :
Par exemple pour la première colonne :
j'aimerai copier la valeur dans A2 dans les cellules qui suivent qui sont vides jusqu'à la cellule non vide c'est à dire avant A19

Merci de votre aide
0
ccm81 Messages postés 10851 Date d'inscription lundi 18 octobre 2010 Statut Membre Dernière intervention 16 avril 2024 2 404
27 févr. 2013 à 06:37
Est ce que c'est ca?
https://www.cjoint.com/?3BBgJCdRoIU
Bonne journée
0

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

Posez votre question
tsangeps Messages postés 7 Date d'inscription mardi 26 février 2013 Statut Membre Dernière intervention 27 février 2013
27 févr. 2013 à 09:10
bonjour,

Merci beaucoup pour votre aide.
La solution fonctionne sur le fichier d'exemple que j'ai donné
mais je ne comprends pas pourquoi il ne marche pas sur le vrai fichier.
Je suis débutante en VB, et il m'indique une erreur pour
For li = 1 To UBound(t) - 1
0
ccm81 Messages postés 10851 Date d'inscription lundi 18 octobre 2010 Statut Membre Dernière intervention 16 avril 2024 2 404
27 févr. 2013 à 09:26
c'est une erreur à la compilation ou à l'exécution?
0
tsangeps Messages postés 7 Date d'inscription mardi 26 février 2013 Statut Membre Dernière intervention 27 février 2013
27 févr. 2013 à 09:39
exactement
quand je fais appel à mon macro il m'indique une erreur à ce niveau
0
ccm81 Messages postés 10851 Date d'inscription lundi 18 octobre 2010 Statut Membre Dernière intervention 16 avril 2024 2 404
27 févr. 2013 à 09:50
tu n'as pas vraiment répondu à ma question

A la compilation.
Tu vas dans l'éditeur VBA , Deboguage.Compiler y a t'il une erreur signalée

A l'exécution. Quand tu appelle ta macro, l'erreur se produit.
Dans l'éditeur VBA, la ligne se met en jaune, tu passes le curseur sur li (quelle valeur donne t'il) puis sur UBound(t) (idem)

As tu mis
Option Base 1
sur la 1° ligne de code (les indices des tableaux commenceront à 1)
0
tsangeps Messages postés 7 Date d'inscription mardi 26 février 2013 Statut Membre Dernière intervention 27 février 2013
27 févr. 2013 à 10:44
ah j'ai personnalisé certaines constantes (comme codeb et cofin ) et ça marche super.

Merci beaucoup de votre aide
0
ccm81 Messages postés 10851 Date d'inscription lundi 18 octobre 2010 Statut Membre Dernière intervention 16 avril 2024 2 404
27 févr. 2013 à 10:46
ah oui, j'avais oublié de le préciser !!!
peux tu mettre le problème à résolu (en haut de ta première demande)

bonne journée
0