FileSystemObject处理文件

本文详细介绍了使用FileSystemObject进行文件创建、读写、移动、复制及删除等基本操作的方法,并提供了VBScript和JScript的具体示例。
有两种主要的文件处理类型:
创建、添加或删除数据,以及读取文件
移动、复制和删除文件
创建文件
创建空文本文件(有时被叫做“文本流”)有三种方法。
第一种方法是用 CreateTextFile 方法。 下面的示例示范了在 VBScript 中如何用这种方法来创建文本文件:
Dim fso, f1
Set fso = CreateObject("Scripting.FileSystemObject")
Set f1 = fso.CreateTextFile("c:/testfile.txt", True)

要在 JScript 中用这种方法,则使用下面的代码:

var fso, f1;
fso = new ActiveXObject("Scripting.FileSystemObject");
f1 = fso.CreateTextFile("c://testfile.txt", true);

请考察示例代码,来领会如何在 FileSystemObject 中使用 CreateTextFile 方法。
创建文本文件的第二种方法是,使用 FileSystemObject 对象的 OpenTextFile 方法,并设置 ForWriting 标志。在 VBScript 中,代码就像下面的示例一样:

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

要在 JScript 中使用这种方法来创建文本文件,则使用下面的代码:

var fso, ts;
var ForWriting= 2;
fso = new ActiveXObject("Scripting.FileSystemObject");
ts = fso.OpenTextFile("c://test.txt", ForWriting, true);

创建文本文件的第三种方法是,使用 OpenAsTextStream 方法,并设置 ForWriting 标志。要使用这种方法,在 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)

在 JScript 中,则使用下面示例中的代码:

var fso, f1, ts;
var ForWriting = 2;
fso = new ActiveXObject("Scripting.FileSystemObject");
fso.CreateTextFile ("c://test1.txt");
f1 = fso.GetFile("c://test1.txt");
ts = f1.OpenAsTextStream(ForWriting, true);

添加数据到文件中
一旦创建了文本文件,使用下面的三个步骤向文件添加数据:

打开文本文件。
写入数据。
关闭文件。
要打开现有的文件,则使用 FileSystemObject 对象的 OpenTextFile 方法或 File 对象的 OpenAsTextStream 方法。
要写数据到打开的文本文件,则根据下表所述任务使用 TextStream 对象的 Write、WriteLine 或 WriteBlankLines 方法。

任务 方法
向打开的文本文件写数据,不用后续一个新行字符。 Write
向打开的文本文件写数据,后续一个新行字符。 WriteLine
向打开的文本文件写一个或多个空白行。 WriteBlankLines


请考察示例代码,来领会如何在 FileSystemObject 对象中使用 Write、WriteLine 和 WriteBlankLines 方法。

要关闭一个打开的文件,则使用 TextStream 对象的 Close 方法。

请考察示例代码,来领会如何在 FileSystemObject 中使用 Close 方法。


--------------------------------------------------------------------------------

注意 新行字符包含一个或几个字符(取决于操作系统),以把光标移动到下一行的开始位置(回车/换行)。注意某些字符串末尾可能已经有这个非打印字符了。

--------------------------------------------------------------------------------


下面的 VBScript 例子示范了如何打开文件,和同时使用三种写方法来向文件添加数据,然后关闭文件:


Sub CreateFile()
Dim fso, tf
Set fso = CreateObject("Scripting.FileSystemObject")
Set tf = fso.CreateTextFile("c:/testfile.txt", True)
' 写一行,并且带有新行字符。
tf.WriteLine("Testing 1, 2, 3.")
' 向文件写三个新行字符。
tf.WriteBlankLines(3)
' 写一行。
tf.Write ("This is a test.")
tf.Close
End Sub
这个示例示范了在 JScript 中如何使用这三个方法:

function CreateFile()
{
var fso, tf;
fso = new ActiveXObject("Scripting.FileSystemObject");
tf = fso.CreateTextFile("c://testfile.txt", true);
// 写一行,并且带有新行字符。
tf.WriteLine("Testing 1, 2, 3.") ;
// 向文件写三个新行字符。
tf.WriteBlankLines(3) ;
// 写一行。
tf.Write ("This is a test.");
tf.Close();
}
读取文件
要从文本文件读取数据,则使用 TextStream 对象的 Read、ReadLine 或 ReadAll 方法。下表描述了不同的任务应使用哪种方法。
任务 方法
从文件读取指定数量的字符。 Read
读取一整行(一直到但不包括新行字符)。 ReadLine
读取文本文件的整个内容。 ReadAll


请考察示例代码,来领会如何在 FileSystemObject 中使用 ReadAll 和 ReadLine 方法。

如果使用 Read 或 ReadLine 方法,并且想跳过数据的特殊部分,则使用 Skip 或 SkipLine 方法。read 方法的结果文本存在一个字符串中,该字符串可以显示在一个控件中,也可以用字符串函数(如 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
"
f1.WriteLine "Hello World"
f1.WriteBlankLines(1)
f1.Close
' 读取文件的内容。
Response.Write "Reading file
"
Set ts = fso.OpenTextFile("c:/testfile.txt", ForReading)
s = ts.ReadLine
Response.Write "File contents = '" & s & "'"
ts.Close
End Sub

下面的代码示范了在 JScript 中做同样的事:

function ReadFiles()
{
var fso, f1, ts, s;
var ForReading = 1;
fso = new ActiveXObject("Scripting.FileSystemObject");
f1 = fso.CreateTextFile("c://testfile.txt", true);
// 写一行。
Response.Write("Writing file
");
f1.WriteLine("Hello World");
f1.WriteBlankLines(1);
f1.Close();
// 读取文件的内容。
Response.Write("Reading file
");
ts = fso.OpenTextFile("c://testfile.txt", ForReading);
s = ts.ReadLine();
Response.Write("File contents = '" + s + "'");
ts.Close();
}

移动、复制和删除文件
FSO 对象模式各有两种方法移动、复制和删除文件,如下表所述。
任务 方法
移动文件 File.Move 或 FileSystemObject.MoveFile
复制文件 File.Copy 或 FileSystemObject.CopyFile
删除文件 File.Delete 或 FileSystemObject.DeleteFile


请考察示例代码,来领会在 FileSystemObject 中删除文件的两种方法。

下面的 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
"
' 写一行。
f1.Write ("This is a test.")
' 关闭文件。
f1.Close
Response.Write "Moving file to c:/tmp
"
' 获取 C 的根目录(C:/)中的文件的句柄。
Set f2 = fso.GetFile("c:/testfile.txt")
' 把文件移动到 /tmp 目录。
f2.Move ("c:/tmp/testfile.txt")
Response.Write "Copying file to c:/temp
"
' 把文件复制到 /temp 目录。
f2.Copy ("c:/temp/testfile.txt")
Response.Write "Deleting files
"
' 获得文件当前位置的句柄。
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

下面的代码示范了在 JScript 中做同样的事:

function ManipFiles()
{
var fso, f1, f2, s;
fso = new ActiveXObject("Scripting.FileSystemObject");
f1 = fso.CreateTextFile("c://testfile.txt", true);
Response.Write("Writing file
");
// 写一行。
f1.Write("This is a test.");
// 关闭文件。
f1.Close();
Response.Write("Moving file to c://tmp
");
// 获取 C 的根目录(C:/)中的文件的句柄。
f2 = fso.GetFile("c://testfile.txt");
// 把文件移动到 /tmp 目录。
f2.Move ("c://tmp//testfile.txt");
Response.Write("Copying file to c://temp
");
// 把文件复制到 /temp 目录。
f2.Copy ("c://temp//testfile.txt");
Response.Write("Deleting files
");
// 获得文件当前位置的句柄。
f2 = fso.GetFile("c://tmp//testfile.txt");
f3 = fso.GetFile("c://temp//testfile.txt");
// 删除文件。
f2.Delete();
f3.Delete();
Response.Write("All done!");

 
在VBA中,使用 **FileSystemObject (FSO)** 提取特定文件类型(如 `.txt`、`.xlsx`)可以通过遍历目录中的文件并检查文件扩展名实现。以下是详细方法和示例代码: --- ### **方法:提取特定文件类型的文件** ```vba Sub ListFilesByExtension() Dim fso As Object, folder As Object, file As Object Dim folderPath As String, fileExtension As String Dim result As String ' 创建FileSystemObject对象 Set fso = CreateObject("Scripting.FileSystemObject") ' 指定目录路径和文件扩展名(如 ".txt") folderPath = "C:\TestFolder" fileExtension = ".txt" ' 可修改为 ".xlsx", ".csv" 等 ' 检查路径是否存在 If Not fso.FolderExists(folderPath) Then MsgBox "目录不存在!", vbExclamation Exit Sub End If ' 获取目录对象 Set folder = fso.GetFolder(folderPath) ' 遍历文件并筛选扩展名 result = "文件列表(扩展名: " & fileExtension & "):" & vbNewLine For Each file In folder.Files If LCase(fso.GetExtensionName(file.Name)) = LCase(Replace(fileExtension, ".", "")) Then result = result & file.Name & vbNewLine End If Next ' 输出结果 MsgBox result, vbInformation, "筛选结果" End Sub ``` --- ### **关键点说明** 1. **`GetExtensionName` 方法** - 返回文件扩展名(不含点号),例如 `fso.GetExtensionName("example.txt")` 返回 `"txt"`。 - 通过 `LCase` 统一转换为小写,避免大小写敏感问题。 2. **扩展名匹配** - 输入扩展名时建议包含点号(如 `.txt`),但在比较时需去掉点号(通过 `Replace(fileExtension, ".", "")`)。 3. **路径验证** - 使用 `FolderExists` 确保目录存在,避免运行时错误。 --- ### **进阶用法** #### **1. 提取多种文件类型** ```vba Sub ListMultipleFileTypes() Dim fso As Object, folder As Object, file As Object Dim folderPath As String, extensions As Variant, ext As Variant Dim result As String Set fso = CreateObject("Scripting.FileSystemObject") folderPath = "C:\TestFolder" extensions = Array(".txt", ".xlsx", ".csv") ' 需筛选的扩展名列表 Set folder = fso.GetFolder(folderPath) result = "文件列表(多扩展名):" & vbNewLine For Each file In folder.Files For Each ext In extensions If LCase(fso.GetExtensionName(file.Name)) = LCase(Replace(ext, ".", "")) Then result = result & file.Name & vbNewLine Exit For End If Next Next MsgBox result, vbInformation End Sub ``` #### **2. 将结果写入Excel** ```vba Sub WriteFilteredFilesToExcel() Dim fso As Object, folder As Object, file As Object Dim ws As Worksheet, i As Long Dim folderPath As String, fileExtension As String Set fso = CreateObject("Scripting.FileSystemObject") folderPath = "C:\TestFolder" fileExtension = ".pdf" ' 筛选PDF文件 Set ws = ThisWorkbook.Sheets(1) i = 1 ws.Cells(1, 1).Value = "文件名" For Each file In fso.GetFolder(folderPath).Files If LCase(fso.GetExtensionName(file.Name)) = LCase(Replace(fileExtension, ".", "")) Then i = i + 1 ws.Cells(i, 1).Value = file.Name End If Next MsgBox "筛选完成!结果已写入Excel。", vbInformation End Sub ``` --- ### **常见问题解决** 1. **扩展名大小写问题** - 使用 `LCase` 或 `UCase` 统一转换为小写/大写,避免因大小写差异导致漏选。 2. **隐藏文件处理** - FSO默认会返回隐藏文件,如需排除,可检查文件属性: ```vba If (file.Attributes And 2) = 0 Then ' 2表示隐藏属性 ' 非隐藏文件 End If ``` 3. **无匹配文件时的提示** - 添加计数器判断是否找到文件: ```vba Dim count As Long count = 0 For Each file In folder.Files ' 匹配逻辑... count = count + 1 Next If count = 0 Then MsgBox "未找到指定类型的文件!", vbExclamation ``` --- ### **总结** | 需求 | 推荐方法 | |---------------------|----------------------------------| | 筛选单一文件类型 | `If fso.GetExtensionName(file.Name) = "txt" Then` | | 筛选多种文件类型 | 使用数组循环匹配(如 `Array(".txt", ".xlsx")`) | | 写入Excel | 通过 `ws.Cells(i, 1).Value = file.Name` 逐行写入 | | 排除隐藏文件 | 检查 `file.Attributes` 属性 | ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值