VB.NET Tips - フォルダコピー(サブフォルダ以下も含む)
指定されたコピー先のフォルダに、コピー元のフォルダ名の中身を全てコピーする関数です。
コピー先のフォルダが存在しない場合は、作成します。
最初にコピー元のフォルダ内のファイルを全てコピー先にコピーを行います。
コピー元のフォルダ内のファイル一覧を取得には System.IO.Directory.GetFiles を用います。
その後で、コピー元のフォルダ内のサブフォルダの一覧を取得し、自分自身を再帰的にコールすることで
コピーを行います。サブフォルダの一覧の取得は System.IO.Directory.GetDirectories を用います。
System.IO.Directory.GetFiles 関数について
Public Shared Function GetFiles (path As String) As String() path: 検索するディレクトリの相対パスまたは絶対パス。 この文字列の大文字と小文字は区別されません。 戻り値: 指定したディレクトリ内のファイルの完全名 (パスを含む) の配列。 ファイルが見つからない場合は空の配列。(空と言うことはLengthが 0 のString配列)
System.IO.Directory.GetDirectories 関数について
Public Shared Function GetDirectories (path As String) As String() path: 検索するディレクトリの相対パスまたは絶対パス。 この文字列の大文字と小文字は区別されません。 戻り値: 指定したパス内のサブディレクトリのフルネーム (パスを含む) の配列。 ディレクトリが見つからない場合は空の配列。(空と言うことはLengthが 0 のString配列)
フォルダコピー関数
''' -----------------------------------------------------------------------
'''
''' フォルダコピー(サブフォルダ以下も含む)
'''
''' コピー元フォルダ
''' コピー先フォルダ
''' True:正常, False:エラー
''' -----------------------------------------------------------------------
Function CopyFolder(ByVal astrSrcFolderName As String, ByVal astrDesFolderName As String) As Boolean
'戻り値初期化
CopyFolder = False
Try
'コピー先のフォルダがないときは作る
If Not System.IO.Directory.Exists(astrDesFolderName) Then
System.IO.Directory.CreateDirectory(astrDesFolderName)
'属性もコピー
System.IO.File.SetAttributes(astrDesFolderName, System.IO.File.GetAttributes(astrSrcFolderName))
End If
'コピー先のフォルダ名の末尾に"\"をつける
If astrDesFolderName.Chars((astrDesFolderName.Length - 1)) <> System.IO.Path.DirectorySeparatorChar Then
astrDesFolderName &= System.IO.Path.DirectorySeparatorChar
End If
'コピー元のフォルダにあるファイルをコピー
Dim ArrFiles As String() = System.IO.Directory.GetFiles(astrSrcFolderName)
Dim strFile As String
For Each strFile In ArrFiles
System.IO.File.Copy(strFile, astrDesFolderName + System.IO.Path.GetFileName(strFile), True)
Next
'コピー元のフォルダにあるフォルダをコピー(再帰呼出)
Dim ArrDirs As String() = System.IO.Directory.GetDirectories(astrSrcFolderName)
Dim strDir As String
For Each strDir In ArrDirs
If CopyFolder(strDir, astrDesFolderName + System.IO.Path.GetFileName(strDir)) = False Then
'再帰呼出での内部のフォルダのコピーがエラーの場合
Return False
End If
Next
'正常終了
Return True
Catch ex As Exception
'エラー処理が必要な場合は、ここに記述する
End Try
End Function