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
|
好了,这篇文章就介绍这么多了,建议大家多看看相关的实例进行学习。