Probléme avec derlgn VBA

GillesBIGBOY -  
 GillesBIGBOY -
Bonjour,

j'ai devellopé une macro avec un ami, qui on fonction d'un tableau virtuel pris d'un autre classeur va créer deux colonnes et appliquer deux formules.
Mon probléme se situe au niveau de :

derLgn = Range("A1").End(xlDown).Row

arriver a ce stade, il y a un message de blocage
eurreur d'exécution "6" dépassement de capacité.

Comment est-ce que je pourais arranger ça ?

Sub Macro1()
'
' Macro pour la création de 2 colonnes
'

Dim tabNatComp As Variant
Dim shA As Worksheet 'Feuille A
Dim wB As Workbook 'Classeur B
Dim derLgn As Integer

Set wB = Workbooks.Open(Filename:="
C:\Users\gboubou\Desktop\Gilles-aut\BISCUIT.xlsm
")
Set shA = wB.Sheets("Base compta")
tabNatComp = shA.Range("A1").CurrentRegion
wB.Close False ' ferme sans sauvegarder
Set wB = Nothing
Set shA = Nothing


Columns("C:C").Insert Shift:=xlToRight, CopyOrigin:=xlFormatFromLeftOrAbove
Range("C1") = "Catégorie"
Columns("D:D").Insert Shift:=xlToRight, CopyOrigin:=xlFormatFromLeftOrAbove
Range("D1") = "Sous Catégorie"

derLgn = Range("A1").End(xlDown).Row

For i = 2 To derLgn
For j = LBound(tabNatComp) To UBound(tabNatComp)
If tabNatComp(j, 1) = Cells(i, 2) Then
Cells(i, 3) = tabNatComp(j, 3)
Cells(i, 4) = tabNatComp(j, 4)
Exit For
End If
Next j
Next i

End Sub

2 réponses

ccm81 Messages postés 11033 Statut Membre 2 433
 
Bonjour

Si tu veux la dernière ligne non vide de la colonne A
Range("A" & Rows.Count).End(xlDown).Row

Cdlmnt
0
GillesBIGBOY
 
Merci pour ta réponse
mais je crois mon probléme doit être ailleurs dans la macro, car j'ai toujours ce message de dépassement de capacité.
0
f894009 Messages postés 17414 Date d'inscription   Statut Membre Dernière intervention   1 715 > GillesBIGBOY
 
Bonjour,
derLgn = Range("A1").End(xlDown).Row

donne la derniere ligne de la colonne si celle si est vide, donc largement supérieur a un Integer

ci dessous, derniere ligne non vide colonne A, =1 si colonne est vide
derLgn= Range("A" & Rows.Count).End(xlUp).Row
0
marc > GillesBIGBOY
 
 
Bonjour GillesBIGBOY,

Ton problème de dépassement de capacité est dû au fait
que la variable derLgn est déclarée As Integer =>

Dim derLgn As Long

Cordialement
 
0
GillesBIGBOY > marc
 
BIEN VUE marc!!!
C'EST BON maintenant
Merci pour toutes vos réponses

marc; ccm81; f894009
0
ccm81 Messages postés 11033 Statut Membre 2 433
 
mais je crois mon probléme doit être ailleurs dans la macro, car j'ai toujours ce message de dépassement de capacité.
toujours sur la même ligne ?
0