DirectoryInfo.MoveTo メソッド
アセンブリ: mscorlib (mscorlib.dll 内)



たとえば、c:\mydir を c:\public に移動しようとしたところ、c:\public が既に存在する場合、このメソッドは IOException をスローします。このような場合は、destDirName パラメータとして "c:\\public\\mydir"を指定するか、"c:\\newdir" などの新しいディレクトリ名を指定する必要があります。
このメソッドでは、読み取り専用ディレクトリにディレクトリを移動できます。このとき、いずれのディレクトリの読み書き属性も影響されません。
その他の一般的な I/O タスクまたは関連する I/O タスクの例を次の表に示します。
Directory.Delete DirectoryInfo.Delete | |
CreateDirectory | |
CreateSubdirectory | |
GetDirectories GetDirectories | |
GetFileSystemInfos | |

Imports System Imports System.IO Public Class MoveToTest Public Shared Sub Main() ' Make a reference to a directory. Dim di As New DirectoryInfo("TempDir") ' Create the directory only if it does not already exist. If di.Exists = False Then di.Create() End If ' Create a subdirectory in the directory just created. Dim dis As DirectoryInfo = di.CreateSubdirectory("SubDir") If Directory.Exists("NewTempDir") = False Then ' Move the main directory. Note that the contents move with the directory. di.MoveTo("NewTempDir") End If Try ' Attempt to delete the subdirectory. Note that because it has been ' moved, an exception is thrown. dis.Delete(True) Catch ' Handle this exception in some way, such as with the following code: ' Console.WriteLine("That directory does not exist."); ' Point the DirectoryInfo reference to the new directory. ' di = New DirectoryInfo("NewTempDir") ' Delete the directory. ' di.Delete(True) End Try End Sub 'Main End Class 'MoveToTest
using System; using System.IO; public class MoveToTest { public static void Main() { // Make a reference to a directory. DirectoryInfo di = new DirectoryInfo("TempDir"); // Create the directory only if it does not already exist. if (di.Exists == false) di.Create(); // Create a subdirectory in the directory just created. DirectoryInfo dis = di.CreateSubdirectory("SubDir"); // Move the main directory. Note that the contents move with the directory. if (Directory.Exists("NewTempDir") == false) di.MoveTo("NewTempDir"); try { // Attempt to delete the subdirectory. Note that because it has been // moved, an exception is thrown. dis.Delete(true); } catch (Exception) { // Handle this exception in some way, such as with the following code: // Console.WriteLine("That directory does not exist."); } // Point the DirectoryInfo reference to the new directory. //di = new DirectoryInfo("NewTempDir"); // Delete the directory. //di.Delete(true); } }
using namespace System; using namespace System::IO; int main() { // Make a reference to a directory. DirectoryInfo^ di = gcnew DirectoryInfo( "TempDir" ); // Create the directory only if it does not already exist. if ( !di->Exists ) di->Create(); // Create a subdirectory in the directory just created. DirectoryInfo^ dis = di->CreateSubdirectory( "SubDir" ); // Move the main directory. Note that the contents move with the directory. if ( !Directory::Exists( "NewTempDir" ) ) di->MoveTo( "NewTempDir" ); try { // Attempt to delete the subdirectory. Note that because it has been // moved, an exception is thrown. dis->Delete( true ); } catch ( Exception^ ) { // Handle this exception in some way, such as with the following code: // Console::WriteLine(S"That directory does not exist."); } // Point the DirectoryInfo reference to the new directory. //di = new DirectoryInfo(S"NewTempDir"); // Delete the directory. //di->Delete(true); }
import System.*; import System.IO.*; public class MoveToTest { public static void main(String[] args) { // Make a reference to a directory. DirectoryInfo di = new DirectoryInfo("TempDir"); // Create the directory only if it does not already exist. if (di.get_Exists() == false) { di.Create(); } // Create a subdirectory in the directory just created. DirectoryInfo dis = di.CreateSubdirectory("SubDir"); // Move the main directory. // Note that the contents move with the directory. if (Directory.Exists("NewTempDir") == false) { di.MoveTo("NewTempDir"); } try { // Attempt to delete the subdirectory. // Note that because it has been // moved, an exception is thrown. dis.Delete(true); } catch (System.Exception exp) { // Handle this exception in some way, such as // with the following code: // Console.WriteLine("That directory does not exist."); } // Point the DirectoryInfo reference to the new directory. //di = new DirectoryInfo("NewTempDir"); // Delete the directory. //di.Delete(true); } //main } //MoveToTest
import System; import System.IO; public class MoveToTest { public static function Main() { // Make a reference to a directory. var di : DirectoryInfo = new DirectoryInfo("TempDir"); // Create the directory only if it does not already exist. if (di.Exists == false) di.Create(); // Create a subdirectory in the directory just created. var dis : DirectoryInfo = di.CreateSubdirectory("SubDir"); // Move the main directory. Note that its contents move also. if (Directory.Exists("NewTempDir") == false) di.MoveTo("NewTempDir"); try { // Attempt to delete the subdirectory. Note that because it has been // moved, an exception is thrown. dis.Delete(true); } catch (Exception) { // Handle this exception in some way, as with the following code: // Console.WriteLine("That directory does not exist."); } // Point the DirectoryInfo reference to the new directory. //di = new DirectoryInfo("NewTempDir"); // Delete the directory. //di.Delete(true); } } MoveToTest.Main();


Windows 98, Windows 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile for Pocket PC, Windows Mobile for Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
開発プラットフォームの中には、.NET Framework によってサポートされていないバージョンがあります。サポートされているバージョンについては、「システム要件」を参照してください。


- DirectoryInfo.MoveTo メソッドのページへのリンク