VBS教程:对象-FileSystemObject 对象

时间:2022-06-01 18:48:47

FileSystemObject 对象

提供对计算机文件系统的访问。

说明

以下代码举例说明如何使用 FileSystemObject 对象返回一个 TextStream 对象,此对象可以被读取或写入:

?
1
2
3
4
5
Dim fso, MyFile
Set fso = CreateObject("Scripting.FileSystemObject")
Set MyFile = fso.CreateTextFile("c:\testfile.txt", True)
MyFile.WriteLine("This is a test.")
MyFile.Close

以前代码中,CreateObject 函数返回 FileSystemObject 对象 (fso)。CreateTextFile 方法创建一个文件作为 TextStream 对象 (a),然后 WriteLine 方法在此文件中写入一行文本。最后 Close 方法刷新缓冲区并关闭文件。

以下是对FileSystemObject 对象的详细解释

文件系统是所有操作系统最重要的部分之一,脚本经常会需要对文件及文件夹进行访问和管理,在Vbs中对桌面和文件系统进行访问的*对象是FileSystemObject(FSO),这个对象特别复杂,是vbs进行文件操作的核心。

FSO包含的常见对象有:

 

对象/集合

描述

Drive

包含储存设备的信息,包括硬盘、光驱、ram盘、网络驱动器

Drives

提供一个物理和逻辑驱动器的列表

File

检查和处理文件

Files

提供包含在文件夹内的所有文件的列表

Folder

检查和处理文件夹

Folders

提供在 Folder 内的所有文件夹的列表

TextStream

对象。用来读写文本文件。

 

如何使用FSO

要用FSO对象模型来编程,使用CreateObject方法来创建FileSystemObject对象,例如:  

Dim fso
Set fso = wscript.createobject("scripting.filesystemobject")

在这个示例中,Scripting 是类型库的名字,而 FileSystemObject 则是想要创建的对象的名字。至此我们获取了fso对象,接下来就可以使用fso对象了。如果要释放的话也很简单,例如:

Set fso = nothing

FileSystemObject对象总共一个属性即Drives

描述:获得所有可用驱动器的集合。

说明:无论是否本地磁盘、插入媒体、可移动媒体驱动器都显示在 Drives 集合中。

具体示例代码如下所示:获取本计算机上所有的磁盘的盘符  

Set fso = CreateObject("Scripting.FileSystemObject")
Set Drivers = fso.Drives
For Each Driver in Drivers
Msgbox Driver.DriveLetter '输出计算机上所有的磁盘盘符
Next

  方法:(仅常用的方法)

  CreateFile

描述:创建一个空文件

语法:object. CreateTextFile(strFile,blnOverWrite)

参数:strFile为文件名称

blnOverWrite为Ture强制覆盖,为False不覆盖

示例:创建文件C:\test.txt

?
1
2
3
4
5
6
7
Dim Fso
'创建FileSystemObject对象
Set Fso = CreateObject("Scripting.FileSystemObject")
'使用CreateTextFile创建文件,不覆盖存在的文件
Fso.CreateTextFile "C:\test.txt",False
'覆盖存在的文件
Fso.CreateTextFile "C:\test.txt",True

CreateFolder

描述:创建一个空的文件夹

语法:object. CreateFolder(strFolder)

参数:strFolder为想要创建的文件夹名称

示例:创建文件夹: c:\test

?
1
2
3
4
5
Dim Fso
'创建FileSystemObject对象
Set Fso = CreateObject("Scripting.FileSystemObject")
'使用MyFolder创建文件夹
Fso.CreateFolder("c:\test")

DeleteFile

描述:删除一个文件

语法:object. DeleteFile (strFile,force)

参数:strFile为想要删除的文件。组成部分中可用通配符。

force如果要删除只读文件,则该值为 True;否则为 False(默认)

示例:删除文件: c:\test.txt   

?
1
2
3
4
5
6
7
Dim Fso
'创建FileSystemObject对象
Set Fso = CreateObject("Scripting.FileSystemObject")
'使用DeleteFile删除指定文件
Fso.DeleteFile("c:\test.txt")
'强制删除只读的文件
Fso.DeleteFile "c:\test.txt",True

DeleteFolder

描述:删除一个文件夹

语法:object. DeleteFolder(strFolder,force)

参数:strFolder为想要删除的文件夹名称。组成部分中可用通配符。

force如果要删除只读文件夹,则该值为 True;否则为 False(默认)

示例:删除文件夹: c:\test

?
1
2
3
4
5
6
7
Dim Fso
'创建FileSystemObject对象
Set Fso = CreateObject("Scripting.FileSystemObject")
'使用DeleteFile删除指定文件
Fso.DeleteFolder("c:\test")
'强制删除只读的文件
Fso.DeleteFolder "c:\test",True

FileExists

描述:判断指定文件是否存在,如果不判断直接修改,代码出现错误,导致代码无法运行或一些状况出现,可以提高你写代码的严谨性

语法:object. FileExists (strFile)

参数:strFile为指定的文件

示例:检查文件: c:\test.txt是否存在

?
1
2
3
4
5
Dim Fso
'创建FileSystemObject对象
Set Fso = CreateObject("Scripting.FileSystemObject")
'使用FileExists判断指定文件是否存在
MsgBox Fso.FileExists("c:\test.txt")

FolderExist

描述:判断指定文件夹是否存在

语法:object. FolderExists (strFolder)

参数:strFolder为指定的文件夹

示例:检查文件夹: c:\test是否存在

?
1
2
3
4
5
Dim Fso
'创建FileSystemObject对象
Set Fso = CreateObject("Scripting.FileSystemObject")
'使用FolderExists判断指定文件夹是否存在
MsgBox Fso.FolderExists("c:\test")

CopyFile

描述:将一个或多个文件从某位置复制到另一位置

语法:object.CopyFile "source", "destination"[, overwrite]

参数:source必选项。表示指定文件的路径。组成部分中可用通配符。

destination必选项。表示目标位置路径

overwrite可选项。Boolean 值表明是否覆盖现有文件。如果是 True,则覆盖文件;如果是 False,则不覆盖现有文件。默认值是 True

示例:将 c:\test.txt文件复制到D:\下

?
1
2
3
4
5
6
7
Dim Fso
'创建FileSystemObject对象
Set Fso = CreateObject("Scripting.FileSystemObject")
'使用CopyFile复制文件到另一个位置,False不覆盖已存在文件
Fso.CopyFile "c:\test.txt","D:\",False
'True覆盖已存在文件
Fso.CopyFile "c:\test.txt","D:\",True

示例:将 c:\下所有的txt文件复制到D:\下

?
1
2
3
4
5
6
7
Dim Fso
'创建FileSystemObject对象
Set Fso = CreateObject("Scripting.FileSystemObject")
'使用*.txt,可以同时将多个文件复制到另一个位置,False不覆盖已存在文件
Fso.CopyFile "c:\*.txt","D:\",False
'True表示覆盖已存在文件
Fso.CopyFile "c:\*.txt","D:\",True

CopyFolder

描述:将文件夹从某位置复制到另一位置

语法:object. CopyFolder "source", "destination"[, overwrite]

参数:source必选项。表示指定文件夹的路径。组成部分中可用通配符。

destination必选项。表示目标位置的路径

overwrite可选项。Boolean 值表明是否覆盖现有文件夹。如果是 True,则覆盖文件夹;如果是 False,则不覆盖现有文件夹。默认值是 True

示例:将 c:\test文件夹复制到D:\下

?
1
2
3
4
5
6
7
Dim Fso
'创建FileSystemObject对象
Set Fso = CreateObject("Scripting.FileSystemObject")
'使用CopyFile复制文件到另一个位置,默认为True覆盖已存在文件
Fso.CopyFolder "c:\test","D:\"
'False不覆盖已存在文件
Fso.CopyFolder "c:\test","D:\",False

MoveFile

描述:将一个或多个文件从某位置移动到另一位置

语法:object.MoveFile source, destination

参数:source必选项。要移动的文件的路径。组成部分中可用通配符。

destination必选项。指定路径,表示要将文件移动到该目标位置。destination 参数不能包含通配符。

示例:将 c:\test文件夹移动到D:\下

?
1
2
3
4
5
Dim Fso
'创建FileSystemObject对象
Set Fso = CreateObject("Scripting.FileSystemObject")
'使用MoveFile移动文件到另一个位置
Fso.MoveFile "c:\test.txt","D:\"

MoveFolder

描述:将一个或多个文件夹从某位置移动到另一位置

语法:object.MoveFolder source, destination

参数:source必选项。要移动的文件夹的路径。组成部分中可用通配符。

destination必选项。指定路径,表示要将文件夹移动到该目标位置。

示例:

?
1
2
3
4
5
Dim Fso
'创建FileSystemObject对象
Set Fso = CreateObject("Scripting.FileSystemObject")
'使用MoveFolder移动文件夹到另一个位置
Fso.MoveFolder "c:\test","D:\"

GetExtensionName

描述:获取文件后缀名

语法:object.MoveFolder source, destination

参数:source必选项。要移动的文件夹的路径。组成部分中可用通配符。

destination必选项。指定路径,表示要将文件夹移动到该目标位置。

示例:获取”c:\test.txt”文件后缀名

?
1
2
3
4
5
6
7
Dim Fso
Dim GetExtensionName
'创建FileSystemObject对象
Set Fso = CreateObject("Scripting.FileSystemObject")
'使用GetExtensionName获取文件后缀名
GetExtensionName = fso.GetExtensionName("c:\test.txt")
MsgBox GetExtensionName '输出txt

GetBaseName

描述:获取文件当前所在文件夹

语法:object.GetBaseName Path

参数:Path必选项。文件路径名。

示例:获取”c:\test.txt”文件名称

?
1
2
3
4
5
6
7
Dim Fso
Dim GetBaseName
'创建FileSystemObject对象
Set Fso = CreateObject("Scripting.FileSystemObject")
'使用GetBaseName获取文件的文件名称
GetBaseName = Fso.GetBaseName("c:\test\test.txt")
MsgBox GetBaseName '输出test

GetParentFolderName

描述:将一个或多个文件夹从某位置移动到另一位置

语法:object.GetParentFolderName Path

参数:Path必选项。文件路径名。

示例:获取”c:\test.txt”文件所在的文件夹

?
1
2
3
4
5
6
7
Dim Fso
Dim GetParentFolderName
'创建FileSystemObject对象
Set Fso = CreateObject("Scripting.FileSystemObject")
'使用GetParentFolderName获取文件当前所在的文件夹
GetParentFolderName = Fso.GetParentFolderName("c:\test\test.txt")
MsgBox GetParentFolderName '输出c:\test

好了,这篇文章就介绍这么多了,建议大家多看看相关的实例进行学习。