C# 檔案類 常用

來源:互聯網
上載者:User

首先要熟悉.NET中處理檔案和檔案夾的操作。File類和Directory類是其中最主要的兩個類。瞭解它們將對後面功能的實現提供很大的便利。
     本節先對和檔案系統相關的兩個.NET類進行簡要介紹。
  System.IO.File類和System.IO.FileInfo類主要提供有關檔案的各種操作,在使用時需要引用System.IO命名空間。下面通過程式執行個體來介紹其主要屬性和方法。
  (1) 檔案開啟方法:File.Open ()
  該方法的聲明如下: 
public static FileStream Open(string path,FileMode mode)
  下面的代碼開啟存放在c:\tempuploads目錄下名稱為newFile.txt檔案,並在該檔案中寫入hello。
private void OpenFile()
{
 FileStream.TextFile=File.Open(@"c:\tempuploads\newFile.txt",FileMode.Append);
 byte [] Info = {(byte)'h',(byte)'e',(byte)'l',(byte)'l',(byte)'o'};
 TextFile.Write(Info,0,Info.Length);
 TextFile.Close();
}
  (2) 檔案建立方法:File.Create()
  該方法的聲明如下:
public static FileStream Create(string path;)
  下面的代碼示範如何在c:\tempuploads下建立名為newFile.txt的檔案。
  由於File.Create方法預設向所有使用者授予對新檔案的完全讀/寫存取權限,所以檔案是用讀/寫存取權限開啟的,必須關閉後才能由其他應用程式開啟。為此,所以需要使用FileStream類的Close方法將所建立的檔案關閉。
private void MakeFile()
{  
    FileStream NewText=File.Create(@"c:\tempuploads\newFile.txt");
 NewText.Close();
} 
        (3) 檔案刪除方法:File.Delete()
  該方法聲明如下:
public static void Delete(string path);
  下面的代碼示範如何刪除c:\tempuploads目錄下的newFile.txt檔案。
private void DeleteFile()
{
 File.Delete(@"c:\tempuploads\newFile.txt");
}
  (4) 檔案複製方法:File.Copy

  該方法聲明如下:

public static void Copy(string sourceFileName,string destFileName,bool overwrite);
  下面的代碼將c:\tempuploads\newFile.txt複製到c:\tempuploads\BackUp.txt。
  由於Cope方法的OverWrite參數設為true,所以如果BackUp.txt檔案已存在的話,將會被複製過去的檔案所覆蓋。
private void CopyFile()
{
 File.Copy(@"c:\tempuploads\newFile.txt",@"c:\tempuploads\BackUp.txt",true);
}
  (5) 檔案移動方法:File.Move
  該方法聲明如下:
public static void Move(string sourceFileName,string destFileName);
  下面的代碼可以將c:\tempuploads下的BackUp.txt檔案移動到c盤根目錄下。
  注意:
  只能在同一個邏輯盤下進行檔案轉移。如果試圖將c盤下的檔案轉移到d盤,將發生錯誤。
private void MoveFile()
{
 File.Move(@"c:\tempuploads\BackUp.txt",@"c:\BackUp.txt");
}
 (6) 設定檔案屬性方法:File.SetAttributes
  該方法聲明如下:
public static void SetAttributes(string path,FileAttributes fileAttributes);
  下面的代碼可以設定檔案c:\tempuploads\newFile.txt的屬性為唯讀、隱藏。
private void SetFile()
{
 File.SetAttributes(@"c:\tempuploads\newFile.txt",
 FileAttributes.ReadOnly|FileAttributes.Hidden);
}
  檔案除了常用的唯讀和隱藏屬性外,還有Archive(檔案存檔狀態),System(系統檔案),Temporary(臨時檔案)等。關於檔案屬性的詳細情況請參看MSDN中FileAttributes的描述。
  (7) 判斷檔案是否存在的方法:File.Exist
  該方法聲明如下:
public static bool Exists(string path);
  下面的代碼判斷是否存在c:\tempuploads\newFile.txt檔案。若存在,先複製該檔案,然後其刪除,最後將複製的檔案移動;若不存在,則先建立該檔案,然後開啟該檔案並進行寫入操作,最後將檔案屬性設為唯讀、隱藏。
if(File.Exists(@"c:\tempuploads\newFile.txt")) //判斷檔案是否存在
{
 CopyFile(); //複製檔案
 DeleteFile(); //刪除檔案
 MoveFile(); //移動檔案
}
else
{
 MakeFile(); //組建檔案
 OpenFile(); //開啟檔案
 SetFile(); //設定檔案屬性
}
  此外,File類對於Text文本提供了更多的支援。
  · AppendText:將文本追加到現有檔案
  · CreateText:為寫入文本建立或開啟新檔案
  · OpenText:開啟現有文字檔以進行讀取
  但上述方法主要對UTF-8的編碼文本進行操作,從而顯得不夠靈活。在這裡推薦讀者使用下面的代碼對txt檔案進行操作。
  · 對txt檔案進行“讀”操作,範例程式碼如下:
StreamReader TxtReader = new StreamReader(@"c:\tempuploads\newFile.txt",System.Text.Encoding.Default);
string FileContent;
FileContent = TxtReader.ReadEnd();
TxtReader.Close();
  · 對txt檔案進行“寫”操作,範例程式碼如下:
StreamWriter = new StreamWrite(@"c:\tempuploads\newFile.txt",System.Text.Encoding.Default);
string FileContent;
TxtWriter.Write(FileContent);
TxtWriter.Close();
  System.IO.Directory類和System.DirectoryInfo類
  主要提供關於目錄的各種操作,使用時需要引用System.IO命名空間。下面通過程式執行個體來介紹其主要屬性和方法。
  (1) 目錄建立方法:Directory.CreateDirectory
  該方法聲明如下:
public static DirectoryInfo CreateDirectory(string path);
  下面的代碼示範在c:\tempuploads檔案夾下建立名為NewDirectory的目錄。
private void MakeDirectory()
{
 Directory.CreateDirectory(@"c:\tempuploads\NewDirectoty");
}
  (2) 目錄屬性設定方法:DirectoryInfo.Atttributes
  下面的代碼設定c:\tempuploads\NewDirectory目錄為唯讀、隱藏。與檔案屬性相同,目錄屬性也是使用FileAttributes來進行設定的。
private void SetDirectory()
{
 DirectoryInfo NewDirInfo = new DirectoryInfo(@"c:\tempuploads\NewDirectoty");
 NewDirInfo.Atttributes = FileAttributes.ReadOnly|FileAttributes.Hidden;
}
  (3) 目錄刪除方法:Directory.Delete
  該方法聲明如下:
public static void Delete(string path,bool recursive);
  下面的代碼可以將c:\tempuploads\BackUp目錄刪除。Delete方法的第二個參數為bool類型,它可以決定是否刪除非空目錄。如果該參數值為true,將刪除整個目錄,即使該目錄下有檔案或子目錄;若為false,則僅當目錄為空白時才可刪除。
private void DeleteDirectory()
{
 Directory.Delete(@"c:\tempuploads\BackUp",true);
}
  (4) 目錄移動方法:Directory.Move
  該方法聲明如下:
public static void Move(string sourceDirName,string destDirName);
  下面的代碼將目錄c:\tempuploads\NewDirectory移動到c:\tempuploads\BackUp。
private void MoveDirectory()
{
 File.Move(@"c:\tempuploads\NewDirectory",@"c:\tempuploads\BackUp");
}
  (5) 擷取目前的目錄下的所有子目錄方法:Directory.GetDirectories
  該方法聲明如下:
public static string[] GetDirectories(string path;);
  下面的代碼讀出c:\tempuploads\目錄下的所有子目錄,並將其儲存到字串數組中。
private void GetDirectory()
{
 string [] Directorys;
 Directorys = Directory. GetDirectories (@"c:\tempuploads");
}
  (6) 擷取目前的目錄下的所有檔案方法:Directory.GetFiles
  該方法聲明如下:
public static string[] GetFiles(string path;);
  下面的代碼讀出c:\tempuploads\目錄下的所有檔案,並將其儲存到字串數組中。
private void GetFile()
{
 string [] Files;
 Files = Directory. GetFiles (@"c:\tempuploads",);
}
  (7) 判斷目錄是否存在方法:Directory.Exist
  該方法聲明如下:
public static bool Exists(
 string path;
);
  下面的代碼判斷是否存在c:\tempuploads\NewDirectory目錄。若存在,先擷取該目錄下的子目錄和檔案,然後其移動,最後將移動後的目錄刪除。若不存在,則先建立該目錄,然後將目錄屬性設為唯讀、隱藏
if(File.Exists(@"c:\tempuploads\NewDirectory")) //判斷目錄是否存在
{
 GetDirectory(); //擷取子目錄
 GetFile(); //擷取檔案
 MoveDirectory(); //移動目錄
 DeleteDirectory(); //刪除目錄
}
else
{
 MakeDirectory(); //組建目錄
 SetDirectory(); //設定目錄屬性
}
  注意:
  路徑有3種方式,目前的目錄下的相對路徑、當前工作盤的相對路徑、絕對路徑。以C:\Tmp\Book為例(假定當前工作目錄為C:\Tmp)。“Book”,“\Tmp\Book”,“C:\Tmp\Book”都表示C:\Tmp\Book。
  另外,在C#中 “\”是特殊字元,要表示它的話需要使用“\\”。由於這種寫法不方便,C#語言提供了@對其簡化。只要在字串前加上@即可直接使用“\”。所以上面的路徑在C#中應該表示為“Book”,@“\Tmp\Book”,@“C:\Tmp\Book”。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.