FileSystemObject 物件

类别:.NET开发 点击:0 评论:0 推荐:

FileSystemObject (FSO) 物件模型包含下列物件和集合物件。

物件 / 集合物件 說明 FileSystemObject 主要物件。其中包含的方法和屬性可讓您建立、刪除與處理磁碟機、資料夾和檔案,並取得相關的資訊。多數與此物件相關的方法和其他 FSO 物件中的方法重覆,這是為了方便起見而提供這些方法。 Drive 物件。其中包含的方法和屬性可讓您收集連到系統的磁碟機資訊,例如磁碟機的共用名稱和可用空間容量。請注意,「磁碟機」並不一定專指硬碟,也可以是 CD-ROM 光碟機、RAM 磁碟機等等。磁碟機並不一定要實際連到系統上,也可以透過網路以邏輯方式連接。 Drives 集合物件。提供連到系統的磁碟機清單,包含實體或邏輯磁碟機。Drives 集合物件包含所有的磁碟機,不論其類型為何。抽取式磁碟機不需要插入媒體,就能出現在這個集合物件中。 File 物件。其中包含的方法和屬性可讓您建立、刪除或移動檔案。也可讓您向系統查詢檔案名稱、路徑和其他各種屬性。 Files 集合物件。提供某個資料夾內包含的所有檔案的清單。 Folder 物件。其中包含的方法和屬性可讓您建立、刪除或移動資料夾。也可讓您向系統查詢資料夾名稱、路徑和其他各種屬性。 Folders 集合物件。提供 Folder 內所有資料夾的清單。 TextStream 物件。可讓您讀取和寫入文字檔。
建立 FileSystemObject 物件

首先,利用 CreateObject 方法建立一個 FileSystemObject 物件。在 VBScript 中請使用下列程式碼來建立 FileSystemObject 的執行個體:

Dim fso Set fso = CreateObject("Scripting.FileSystemObject")

這段範例程式碼說明如何建立 FileSystemObject 的執行個體。

使用適當的方法

其次,使用 FileSystemObject 物件的適當方法。舉例來說,若要建立新的物件,請使用 CreateTextFileCreateFolder (FSO 物件模型不支援建立或刪除磁碟機)。

若要刪除物件,請使用 FileSystemObject 物件的 DeleteFileDeleteFolder 方法,或 FileFolder 物件的 Delete 方法。您也可以利用適當的方法,來複製和移動檔案與資料夾。

備註    FileSystemObject 物件模型的某些功能是重複的。例如,您可以利用 FileSystemObject 物件的 CopyFile 方法或 File 物件的 Copy 方法來複製檔案。這兩種方法可達到相同的效果;同時存在的目的是為了提供程式設計的彈性。

存取現有的磁碟機、檔案和資料夾

若要存取現有的磁碟機、檔案或資料夾,請使用 FileSystemObject 物件中適當的「Get」方法: GetDrive GetFolder GetFile

若要在 VBScript 中存取現有的檔案:

Dim fso, f1 Set fso = CreateObject("Scripting.FileSystemObject") Set f1 = fso.GetFile("c:\test.txt")

請勿對剛建立的物件使用「Get」方法,因為「Create」函數已經將物件代碼傳回該物件。舉例來說,如果您使用 CreateFolder 方法建立一個新的資料夾,請勿使用 GetFolder 方法 來存取它的屬性,例如 NamePathSize 等等。請為 CreateFolder 函數設定一個變數,為剛建立的資料夾取得一個控制碼,然後再存取它的 屬性、方法和事件。在 VBScript 中可使用下列程式碼來完成上述操作:

Sub CreateFolder    Dim fso, fldr    Set fso = CreateObject("Scripting.FileSystemObject")    Set fldr = fso.CreateFolder("C:\MyTest")    Response.Write "Created folder: " & fldr.Name End Sub 存取物件的屬性

當您擁有物件的控制碼時,便可存取它的屬性。舉例來說,若要取得特定資料夾的名稱,請先 建立一個物件的執行個體,然後利用適當的方法 (在此例中為 GetFolder 方法,因為資料夾已經存在) 為它指定一個控制碼。

在 VBScript 中請使用下列程式碼為 GetFolder 方法指定一個控制碼:

Set fldr = fso.GetFolder("c:\")

您現在擁有 Folder 物件的控制碼了,所以可查看它的 Name 屬性。在 VBScript 中請使用下列程式碼來查看屬性:

Response.Write "Folder name is: " & fldr.Name

若要查看檔案最後一次修改的時間,請使用下列的 VBScript 語法:

Dim fso, f1 Set fso = CreateObject("Scripting.FileSystemObject") ' 取得一個要查詢的File 物件。 fso.GetFile("c:\detlog.txt")    ' 列印訊息。 Response.Write "File last modified: " & f1.DateLastModified

料夾的處理

下表列出常見的資料夾任務和執行這些任務的方法。

任務 方法 建立資料夾。 FileSystemObject.CreateFolder 刪除資料夾。 Folder.Delete 或 FileSystemObject.DeleteFolder 移動資料夾 Folder.Move 或 FileSystemObject.MoveFolder 複製資料夾。 Folder.Copy 或 FileSystemObject.CopyFolder 擷取資料夾的名稱。 Folder.Name 檢查磁碟機上是否存在某個資料夾。 FileSystemObject.FolderExists 取得現有的 Folder 物件的執行個體。 FileSystemObject.GetFolder 找出資料夾的上層資料夾名稱。 FileSystemObject.GetParentFolderName 找出系統資料夾的路徑。 FileSystemObject.GetSpecialFolder


Sub ShowFolderInfo()
   Dim fso, fldr, s
   ' 取出FileSystemObject的個體執行。
   Set fso = CreateObject("Scripting.FileSystemObject")
   ' 取出Drive 物件。
   Set fldr = fso.GetFolder("c:")
   ' 列印上層資料夾名稱。
   Response.Write "Parent folder name is: " & fldr & "<br>"
   ' 列印磁碟名稱。
   Response.Write "Contained on drive " & fldr.Drive & "<br>"
   ' 列印根檔案名稱。
   If fldr.IsRootFolder = True Then
      Response.Write "This is the root folder." & ""<br>"<br>"
   Else
      Response.Write "This folder isn't a root folder." & "<br><br>"
   End If
   ' 用FileSystemObject 物件建立一個新的資料夾。
   fso.CreateFolder ("C:\Bogus")
   Response.Write "Created folder C:\Bogus" & "<br>"
   ' 列印這個資料夾的base name 。
   Response.Write "Basename = " & fso.GetBaseName("c:\bogus") & "<br>"
   ' 刪除新建立的資料夾。
   fso.DeleteFolder ("C:\Bogus")
   Response.Write "Deleted folder C:\Bogus" & "<br>"
End Sub

檔案的處理

檔案的處理分為兩大類: 建立、加入或移除資料,以及讀取檔案 移動、複製和刪除檔案 建立檔案

有三種方法可建立空白的文字檔 (有時稱為「文字資料流」)。

第一種方法是使用 CreateTextFile 方法。下面的範例說明如何使用此種方法在 VBScript 中建立文字檔:

Dim fso, f1 Set fso = CreateObject("Scripting.FileSystemObject") Set f1 = fso.CreateTextFile("c:\testfile.txt", True)

建立文字檔的第二種方法是使用設定 ForWriting 旗標之 FileSystemObject 物 件的 OpenTextFile 方法。在 VBScript 中的程式碼就如下面的範例所示:

Dim fso, ts Const ForWriting = 2 Set fso = CreateObject("Scripting. FileSystemObject") Set ts = fso.OpenTextFile("c:\test.txt", ForWriting, True)

 

建立文字檔的第三種方法是使用設定 ForWriting 旗標的 OpenAsTextStream 方法。採用此種方法時,請在 VBScript 中使用下列程式碼:

Dim fso, f1, ts Const ForWriting = 2 Set fso = CreateObject("Scripting.FileSystemObject") fso.CreateTextFile ("c:\test1.txt") Set f1 = fso.GetFile("c:\test1.txt") Set ts = f1.OpenAsTextStream(ForWriting, True)將資料加入檔案中

建立好文字檔後,可依下列三個步驟將資料加入檔案:

開啟文字檔。

寫入資料。

關閉檔案。

若要開啟現有的檔案,請使用 FileSystemObject 物件的 OpenTextFile 方法或 File 物件的 OpenAsTextStream 方法。

若要將資料寫入已開啟的文字檔中,請依下表列出的不同任務使用 TextStream 物件的 Write、WriteLine 或 WriteBlankLines 方法。

任務方法將資料寫入開啟的文字檔,但不加入換行字元。Write將資料寫入開啟的文字檔,並加入換行字元。WriteLine在開啟的文字檔中寫入一或多行空白行。WriteBlankLines

若要關閉開啟的檔案,請使用 TextStream 物件的 Close 方法。

備註  換行字元包含一或多個字元 (視 作業系統而定),可讓游標移到下一行的開頭 (復位字元/跳行)。請注意,某些字串的結尾可能 已經包含這類非列印字元。

下面的 VBScript 範例說明如何開啟檔案、使用三種寫入方法將資料加入檔案,以及關閉檔案:

Sub CreateFile()    Dim fso, tf    Set fso = CreateObject("Scripting.FileSystemObject")    Set tf = fso.CreateTextFile("c:\testfile.txt", True)    ' Write a line with a newline character.    tf.WriteLine("Testing 1, 2, 3.")    ' Write three newline characters to the file.           tf.WriteBlankLines(3)    ' Write a line.    tf.Write ("This is a test.")    tf.Close End Sub讀取檔案

若要從文字檔中讀取資料,請使用 TextStream 物件的 Read、ReadLine 或 ReadAll 方法。下表說明不同的任務應使用何種方法。

任務方法從檔案中讀取特定數量的字元。Read讀取一整行 (不含換行字元)。ReadLine讀取文字檔的完整內容。ReadAll

如果您使用 Read 或 ReadLine 方法,並想跳移到特定位置的資料,請使用 Skip 或 SkipLine 方法。各種讀取方法所取得的結果文字會存成字串,該字串 可在控制項中顯示,由字串函數剖析 (例如 Left、Right 和 Mid) 或加 以串連。

下面的 VBScript 範例說明如何開啟檔案、寫入檔案,以及讀取檔案:

Sub ReadFiles    Dim fso, f1, ts, s    Const ForReading = 1    Set fso = CreateObject("Scripting.FileSystemObject")    Set f1 = fso.CreateTextFile("c:\testfile.txt", True)    ' 撰寫一行。    Response.Write "Writing file <br>"    f1.WriteLine "Hello World"    f1.WriteBlankLines(1)    f1.Close    ' 讀取檔案內容。    Response.Write "Reading file <br>"    Set ts = fso.OpenTextFile("c:\testfile.txt", ForReading)    s = ts.ReadLine    Response.Write "File contents = '" & s & "'"    ts.Close End Sub移動、複製和刪除檔案

下表說明 FSO 物件模型提供的兩種移動、複製和刪除檔案的方法。

任務方法移動檔案File.Move 或 FileSystemObject.MoveFile複製檔案File.Copy 或 FileSystemObject.CopyFile刪除檔案File.Delete 或 FileSystemObject.DeleteFile

下面的 VBScript 範例在磁碟機 C 的根目錄建立一個文字檔,在檔案中寫入一些資訊,將檔案 移到 \tmp 目錄,將檔案複製到 \temp 目錄,然後再從這兩個目錄中刪除檔案。

若要執行下列範例,請在磁碟機 C: 的根目錄建立 \tmp 和 \temp 目錄:

Sub ManipFiles    Dim fso, f1, f2, s    Set fso = CreateObject("Scripting.FileSystemObject")    Set f1 = fso.CreateTextFile("c:\testfile.txt", True)    Response.Write "Writing file <br>"    ' 撰寫一行。    f1.Write ("This is a test.")    ' 關閉寫入的檔案。    f1.Close    Response.Write "Moving file to c:\tmp <br>"    ' 在C:\的根目錄底下取得一個控制碼。    Set f2 = fso.GetFile("c:\testfile.txt")    ' 移動檔案到\tmp 目錄。    f2.Move ("c:\tmp\testfile.txt")    Response.Write "Copying file to c:\temp <br>"    ' 複製檔案到\temp。    f2.Copy ("c:\temp\testfile.txt")    Response.Write "Deleting files <br>"    ' 取得到檔案目前位置的控制碼。    Set f2 = fso.GetFile("c:\tmp\testfile.txt")    Set f3 = fso.GetFile("c:\temp\testfile.txt")    ' 刪除檔案。    f2.Delete    f3.Delete    Response.Write "All done!" End Sub

本文地址:http://com.8s8s.com/it/it43017.htm