ListObject : Enlarge the range of an existing table

Flavien

Board Regular
Joined
Jan 8, 2023
Messages
79
Office Version
  1. 365
Platform
  1. Windows
Hello!!
Tableau_Suvi.JPG


I have a listobject named "Tableau_Suivi". How can I do with VBA to include the last rows in the table? (The number of rows to be added may vary)

Rich (BB code):
Sub essai2()

Dim table1 As ListObject
Dim rg As Range
Dim CL As Workbook

    Set CL = ThisWorkbook 
        
    Set table1 = ThisWorkbook.Worksheets("SUIVI").ListObjects("Tableau_Suivi")

    table1.Unlist

    Set rg = CL.Worksheets("SUIVI").Cells(2, 1).CurrentRegion
    
    ActiveSheet.ListObjects.Add(xlSrcRange, rg, , xlYes).Name = "Tableau_Suivi"
     

End Sub

Currently, I go through an "unlist" step and then I select the whole thing to rename it "Tableau_Suivi", but I think there is a more "pro" way to do it?


in advance, thank you for your help
 

Excel Facts

Whats the difference between CONCAT and CONCATENATE?
The newer CONCAT function can reference a range of cells. =CONCATENATE(A1,A2,A3,A4,A5) becomes =CONCAT(A1:A5)
Using what you already have, here is one way.
You might want to check your Table Setting in options. Typically when you add rows to the table like you have it will automatically include them in the table.

VBA Code:
Sub essai2()

Dim table1 As ListObject
Dim rg As Range
Dim CL As Workbook

    Set CL = ThisWorkbook
        
    Set table1 = ThisWorkbook.Worksheets("SUIVI").ListObjects("Tableau_Suivi")
    table1.Resize table1.Range.CurrentRegion

End Sub
 
Upvote 0
VBA Code:
Sub essai2_1()
    Dim table1 As ListObject
    Dim CL As Workbook

    Set CL = ThisWorkbook

    Set table1 = CL.Worksheets("SUIVI").ListObjects(1)    'or ListObjects("Tableau_Suivi")
    table1.Resize table1.Range.CurrentRegion

End Sub
Artik
 
Upvote 0
Using what you already have, here is one way.
You might want to check your Table Setting in options. Typically when you add rows to the table like you have it will automatically include them in the table.

VBA Code:
Sub essai2()

Dim table1 As ListObject
Dim rg As Range
Dim CL As Workbook

    Set CL = ThisWorkbook
       
    Set table1 = ThisWorkbook.Worksheets("SUIVI").ListObjects("Tableau_Suivi")
    table1.Resize table1.Range.CurrentRegion

End Sub
Hello Alex,

Thank you for your reply. your code works fine!

I use this type of code (below) to insert rows into my table, but as you can see (cf. picture), the line doesn't fit into the table but immediately below it, which forces me to resize it every time I add it. How do I make the row I insert part of the table?

Rich (BB code):
Sub ESSAI2()

    ThisWorkbook.Worksheets("Feuil1").Range("A2:D2").Copy
    
'   Find the last line used
    DerniereLigne = ThisWorkbook.Worksheets("Feuil2").Cells(Rows.Count, 1).End(xlUp).Row
    
'   Select the following row
    ThisWorkbook.Worksheets("Feuil2").Cells(DerniereLigne, 1).Offset(1, 0).Select

    
    Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False

End Sub
 

Attachments

  • Capture3.JPG
    Capture3.JPG
    39 KB · Views: 33
Upvote 0
It would be preferable to work with the actual table name but try replacing your last line code with this one.
VBA Code:
'   Find the last line used
    DerniereLigne = ThisWorkbook.Worksheets("Feuil1").Columns("A").Find(What:="*", SearchOrder:=xlByRows, SearchDirection:=xlPrevious).Row
 
Upvote 0
It would be preferable to work with the actual table name but try replacing your last line code with this one.
VBA Code:
'   Find the last line used
    DerniereLigne = ThisWorkbook.Worksheets("Feuil1").Columns("A").Find(What:="*", SearchOrder:=xlByRows, SearchDirection:=xlPrevious).Row

Alex,

Thank you for your answer.
On the other hand, how would you do it by calling the table?
 
Upvote 0
Sheet("Feuil1") => Tableau1
Sheet("Feuil2") => Tableau13

FYI,
The size of Tablef "Tableau1" will always be the same, but the size of Table "Tableau13" will be constantly fed by the data entered in "Tableau1"
 
Upvote 0
This is only addressing the destination table but here is one way of using table references:
VBA Code:
Sub ESSAI2_Table()
    Dim rngDerniereLigne As Range
    Dim tbl1 As ListObject, tbl2 As ListObject
    
    Set tbl1 = ThisWorkbook.Worksheets("Feuil1").ListObjects("Tableau1")
    Set tbl2 = ThisWorkbook.Worksheets("Feuil2").ListObjects("Tableau13")
    
    ThisWorkbook.Worksheets("Feuil1").Range("A2:D2").Copy
    
'   Find the last line used based on first column in table
    Set rngDerniereLigne = tbl2.ListColumns(1).Range.Find(What:="*", SearchOrder:=xlByRows, SearchDirection:=xlPrevious)
    
'   Select the following row
    rngDerniereLigne.Offset(1).PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False

End Sub
 
Upvote 0

Forum statistics

Threads
1,225,730
Messages
6,186,698
Members
453,369
Latest member
positivemind

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top