1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96
| Public Sub CopierFeuilleExcel(ByVal sMonBookDeCopie As String, ByVal sMonBookDeDestination As String, _
ByVal sNomFeuilleACopier As String, ByVal sNomFeuilleCopier As String)
If Dir(sMonBookDeCopie) <> "" And Dir(sMonBookDeDestination) <> "" Then
Dim xlApp As Microsoft.Office.Interop.Excel.Application
Dim xlBookDeCopie As Microsoft.Office.Interop.Excel.Workbook
Dim xlBookDeDestination As Microsoft.Office.Interop.Excel.Workbook
Dim i As Integer
Dim j As Integer
If sMonBookDeCopie <> sMonBookDeDestination Then
xlApp = CreateObject("Excel.Application")
xlBookDeCopie = xlApp.Workbooks.Open(sMonBookDeCopie)
xlBookDeDestination = xlApp.Workbooks.Open(sMonBookDeDestination)
For i = 1 To xlBookDeCopie.Sheets.Count
If xlBookDeCopie.Sheets(i).Name = sNomFeuilleACopier Then
xlBookDeCopie.Activate()
xlBookDeCopie.Sheets(sNomFeuilleACopier).Select()
xlBookDeCopie.Sheets(sNomFeuilleACopier).Copy(After:=xlBookDeDestination. _
Sheets(xlBookDeDestination.Sheets.Count))
For j = 1 To xlBookDeDestination.Sheets.Count
If xlBookDeDestination.Sheets(j).Name = sNomFeuilleCopier Then
MsgBox("La feuille copiée n'a pas pu être renommée, ce nom existe déjà!", MsgBoxStyle.Critical)
Exit For
ElseIf j = xlBookDeDestination.Sheets.Count Then
xlBookDeDestination.Sheets(j).Name = sNomFeuilleCopier
End If
Next j
Exit For
ElseIf i = xlBookDeCopie.Sheets.Count Then
MsgBox("La feuille à copier n'existe pas!", MsgBoxStyle.Critical)
End If
Next i
xlBookDeCopie.Close(True)xlBookDeDestination.Close(
True)
xlApp.Quit()
xlBookDeCopie = Nothing
xlBookDeDestination = Nothing
xlApp = Nothing
ElseIf sMonBookDeCopie = sMonBookDeDestination Then
xlApp = CreateObject("Excel.Application")
xlBookDeCopie = xlApp.Workbooks.Open(sMonBookDeCopie)
For i = 1 To xlBookDeCopie.Sheets.Count
If xlBookDeCopie.Sheets(i).Name = sNomFeuilleACopier Then
xlBookDeCopie.Activate()
xlBookDeCopie.Sheets(sNomFeuilleACopier).Select()
xlBookDeCopie.Sheets(sNomFeuilleACopier).Copy(After:=xlBookDeCopie. _
Sheets(xlBookDeCopie.Sheets.Count))
For j = 1 To xlBookDeCopie.Sheets.Count
If xlBookDeCopie.Sheets(j).Name = sNomFeuilleCopier Then
MsgBox("La feuille copiée n'a pas pu être renommée, ce nom existe déjà!", MsgBoxStyle.Critical)
Exit For
ElseIf j = xlBookDeCopie.Sheets.Count Then
xlBookDeCopie.Sheets(j).Name = sNomFeuilleCopier
End If
Next j
Exit For
ElseIf i = xlBookDeCopie.Sheets.Count Then
MsgBox("La feuille à copier n'existe pas!", MsgBoxStyle.Critical)
End If
Next ixlBookDeCopie.Close(True)
xlApp.Quit()
xlBookDeCopie = Nothing
xlApp = Nothing
End If
Else
MsgBox("Le fichier n'existe pas, vérifier le chemin !", MsgBoxStyle.Critical)
End If
End Sub |
Partager