Copier une plage avec une zone à une feuille de base de données en utilisant VBA dans Microsoft Excel
-
Les exemples de codes seront copiés dans une feuille de base de données avec le nom Sheet2.
-
Chaque fois que vous exécutez l’un des sous-marins, les cellules seront placées sous la dernière ligne avec des données ou après la dernière colonne avec des données dans sheet2.
-
Pour chaque exemple, il existe une macro qui fait une copie normale et une qui ne fait que copier les valeurs.
-
Les exemples de sous-marins utilisent les fonctions ci-dessous (les macros ne fonctionneront pas sans les fonctions).
Sub CopyOneArea() Dim sourceRange As Range Dim destrange As Range Dim Lr As Long Lr = LastRow(Sheets("Sheet2")) + 1 Set sourceRange = Sheets("Sheet1").Range("A1:c10") Set destrange = Sheets("Sheet2").Range("A" & Lr) sourceRange.Copy destrange End Sub Sub CopyOneAreaValues() Dim sourceRange As Range Dim destrange As Range Dim Lr As Long Lr = LastRow(Sheets("Sheet2")) + 1 Set sourceRange = Sheets("Sheet1").Range("A1:c10") With sourceRange Set destrange = Sheets("Sheet2").Range("A" & Lr). _ Resize(.Rows.Count, .Columns.Count) End With destrange.Value = sourceRange.Value End Sub Function LastRow(sh As Worksheet) On Error Resume Next LastRow = sh.Cells.Find(What:="*", _ After:=sh.Range("A1"), _ Lookat:=xlPart, _ LookIn:=xlFormulas, _ SearchOrder:=xlByRows, _ SearchDirection:=xlPrevious, _ MatchCase:=False).Row On Error GoTo 0 End Function Function Lastcol(sh As Worksheet) On Error Resume Next Lastcol = sh.Cells.Find(What:="*", _ After:=sh.Range("A1"), _ Lookat:=xlPart, _ LookIn:=xlFormulas, _ SearchOrder:=xlByColumns, _ SearchDirection:=xlPrevious, _ MatchCase:=False).Column On Error GoTo 0 End Function