您现在的位置是:主页 > VBA >
excel VBA 操作文件的主要方法 利用Excel对象来处理文件
发布时间:2023-10-10 16:54:33所属栏目:VBA 已帮助人编辑作者:Excel自学教程
利用Excel对象自带的方法来操作文件是最方便,也是最简单的。我们主要利用Workbooks集合和Workbook对象的方法来操作文件。
1、打开Excel文件
我们可以用Workbooks.Open方法打开一个Excel工作簿。
Workbooks.Open(FileName, UpdateLinks, ReadOnly, Format, Password, WriteResPassword, IgnoreReadOnlyRecommended, Origin, Delimiter, Editable, Notify, Converter, AddToMru, Local, CorruptLoad)
其中FileName是必选的参数,表示要打开的工作簿名,如果没有指定路径,则代表当前路径。另外14个是可选参数,除了密码参数,其他的一般很少用。具体的含义可以参看VBA的帮助。例如可以用以下代码来打开 F 盘的 test.xls 文件:

Workbooks.Open "F:/test.xls"
2、打开文本文件
使用Open方法也可以打开文本文件,但建议使用OpenText方法。此方法是载入一个文本文件,并将其作为包含单个工作表的工作簿进行分列处理,然后在此工作表中放入经过分列处理的文本文件数据。完整语法如下:
Workbooks.OpenText(FileName, Origin, StartRow, DataType, TextQualifier, ConsecutiveDelimiter, Tab, Semicolon, Comma, Space, Other, OtherChar, FieldInfo, TextVisualLayout, DecimalSeparator, ThousandsSeparator, TrailingMinusNumbers, Local)
关于以上参数的具体含义可以参看VBA的帮助,这里就不重复了。在实际的编程中,一般无需对这些复杂的参数进行处理。可以通过录制宏来得到打开一个文本文件的VBA代码。具体方法就是选择“文件——打开”,然后选择打开文本文件,就会出现文本导入向导,一步一步执行完,直到文本打开后,停止录制。以下是录制宏得到的代码,在实际编程中只要做相应的修改就可以使用了:
Sub Macro1()
'
' Macro1 Macro
' www.office26.com
'
'
Workbooks.OpenText Filename:="F:/CallWindowProc.txt", Origin:=xlWindows, _
StartRow:=1, DataType:=xlDelimited, TextQualifier:=xlDoubleQuote, _
ConsecutiveDelimiter:=False, Tab:=True, Semicolon:=False, Comma:=False _
, Space:=False, Other:=False, FieldInfo:=Array(1, 1), _
TrailingMinusNumbers:=True
End Sub
3、打开其他文件
利用Excel对象还可以打开XML文件和一些数据库(如Access)文件,对应XML文件,需要Excel2003以上的版本。
1、OpenXML方法的语法如下:
Workbooks.OpenXML(Filename, Stylesheets, LoadOption)
FileName String 类型,必需。要打开的文件名。
Stylesheets Variant 类型,可选。单个值或值的数组,用于指定要应用哪些 XSL 转换 (XSLT) 样式表处理指令。
LoadOption Variant 类型,转换。指定 Excel 打开 XML 数据文件的方式。可为 XlXmlLoadOption 常量之一。
XlXmlLoadOption 可为以下 XlXmlLoadOption 常量之一:
xlXmlLoadImportToList 将 XML 数据文件的内容置于 XML 列表中。
xlXmlLoadMapXml 在“XML 结构”任务窗格中显示 XML 数据文件的架构。
xlXmlLoadOpenXml 打开 XML 数据文件。文件的内容将展开。
xlXmlLoadPromptUser 提示用户选择打开文件的方式。
示例,下面的代码打开了 XML 数据文件“customers.xml”并在 XML 列表中显示了此文件的内容:
Sub UseOpenXML()
Application.Workbooks.OpenXML _
Filename:="customers.xml", _
LoadOption:=xlXmlLoadImportToList
End Sub
2、OpenDatabase 方法语法如下:
Workbooks.OpenDatabase(FileName, CommandText, CommandType, BackgroundQuery, ImportDataAs)
FileName String 类型,必需。连接字符串。
CommandText Variant 类型,可选。查询的命令文本。
CommandType Variant 类型,可选。查询的命令类型。以下是可用的命令类型:Default、SQL 和 Table。
BackgroundQuery Variant 类型,可选。查询的背景。
ImportDataAs Variant 类型,可选。确定查询的格式。
示例:本示例中,Excel 打开了“northwind.mdb”文件。
Sub OpenDatabase()
Workbooks.OpenDatabase FileName:="C:/northwind.mdb"
End Sub
4、保存文件
文件的保存使用Workbook对象的Save或SaveAs方法。Save方法使用简单,语法为:
expression.Save,expression是某个Workbook对象。
如:ActiveWorkbook.Save 即保存当前活动工作簿。
如果是第一次保存工作簿或要另存为,请使用 SaveAs 方法为该文件指定文件名。
其语法为:
expression.SaveAs(FileName, FileFormat, Password, WriteResPassword, ReadOnlyRecommended, CreateBackup, AccessMode, ConflictResolution, AddToMru, TextCodepage, TextVisualLayout, Local)
具体参数含义可参看VBA帮助,使用都比较简单。
示例:本示例新建一个工作簿,提示用户输入文件名,然后保存该工作簿。
Set NewBook = Workbooks.Add
Do
fName = Application.GetSaveAsFilename
Loop Until fName <> False
NewBook.SaveAs Filename:=fName
Application.GetSaveAsFilename为调出标准的“另存为”对话框,获取用户文件名,但并不真正保存任何文件,然后使用代码保存文件。还有Application.GetOpenFileName可以调出标准的“打开”对话框。
5、关闭文件
关闭文件可以使用Workbooks集合或Workbook对象的 Close 方法。前者是关闭所有打开的工作簿,后者关闭特定的工作簿。
Workbook对象的 Close 方法语法为:
expression.Close(SaveChanges, Filename, RouteWorkbook)
SaveChanges参数表示是否保存更改,对许多不需要更改的操作,可设置为False以免弹出保存更改提示的对话框。
FileName 可选。以此文件名保存所做的更改。
RouteWorkbook 可选。如果指定工作簿不需要传送给下一个收件人(没有传送名单或已经传送),则忽略该参数。
示例: 本示例关闭 Book1.xls,并放弃所有对此工作簿的更改。
Workbooks("BOOK1.XLS").Close SaveChanges:=False
本示例关闭所有打开的工作簿。如果某个打开的工作簿有改变,Microsoft Excel 将显示询问是否保存更改的对话框和相应提示。
Workbooks.Close
6、综合实例
假如F盘有一个Excel文件test.xls,现在有另一个Excel文件要访问test.xls的数据,我们来看用VBA代码如何操作。代码如下:
Public Sub test()
Application.ScreenUpdating = False
Workbooks.Open "f:/test.xls"
ThisWorkbook.Sheets(1).Range("b1") = ActiveWorkbook.Sheets(1).Range("a2")
ActiveWorkbook.Close
Application.ScreenUpdating = True
End Sub
首先关闭屏幕刷新,是为了防止test.xls在打开时被看见(有时候还是看的见)。打开后,见test.xls的Sheet1的单元格A2中的值赋给当前工作簿的Sheet1的单元格B2,然后关闭test.xls。
当要打开的工作簿不确定的时候,可以通过调用打开对话框来让用户自己选择。可改为如下:
Public Sub test()
Application.ScreenUpdating = False
Dim Filename as String
Filename = Application.GetOpenFileName
Workbooks.Open Filename
ThisWorkbook.Sheets(1).Range("b1") = ActiveWorkbook.Sheets(1).Range("a2")
ActiveWorkbook.Close
Application.ScreenUpdating = True
End Sub
小结
利用Excel对象的方法进行文件操作是最简单,也是最方便的,适合初学者。对于Excel文件格式,如果我们仅仅是读取其表格中的内容,这种方法也是首选。对于文本文件的操作,使用第二种方法比较方便,若要将文本转换成表格,那么使用此方法也是合适的
以上就是excel自学教程为您提供excel VBA 操作文件的主要方法 利用Excel对象来处理文件的解读,本文章链接: http://www.5enet.cn/Excel_VBA/78194.html 欢迎分享转载,更多相关资讯请前往VBA
相关文章
- Excel VBA 窗体之特殊形状窗体 几何形状组合窗体 实现代码
- VBA非登陆下载Excel文件并处理例子
- Excel VBA 窗体之去除窗体关闭按钮 实现代码
- excel中vba变量类型和dim语句进行一些小结
- excel VBA中textbox的MaxLength属性限制文本框输入长度的设置方法
- excel 隔行插入一行的两种方法,通过技巧和VBA操作来实现excel隔行插入一行
- Excel VBA 窗体之添加最大最小化按钮 实现代码
- VBA读取txt文件内容到excel,vba读取txt文件固定位置
- excel中vba的属性和方法,以及属性方法的区别
- excel VBA那点事之自动排班
猜你喜欢
excel利用VBA转化公式中区域的引用类型
Excel公式中对区域或单元格的引用有多种引用类型,如: $A$1 绝对行和绝对列...
excel 合并工作表的方法,用VBA代码实现合并工作表
下图所示:一个文件夹下面有多个excel工作薄,每个工作薄文件下面有不固定张...
excel VBA字典技术_excel按类别拆分工作簿
工作中有时候需要将一张表格拆分为若干个新表,如下图为某电商销售信息表...
excel vba if判断语句的使用方法,在最后以一个实例来剖析vba if语句的具体应用
vba if语句为判断语句。根据条件的值,可使用 If...Then...Else 语句运行指定的语...
企业IT外包服务
怎样清除Excel单元格中看不见的字符串
Excel中如何不复制隐藏的单元格
excel 如何快速将公式值转数值
Excel单元格内如何换行,这几招快拿小本本记下来
excel 不能自动求和的6大原因,并同时针对不同原因给出不同的解决方法来处理
COUNT函数使用策略
excel 如何删除数据
excel如何利用最简单的方法批量制作条形码?
excel 如何利用分列快速提取出生年月日
Excel中LEN函数的语法和用法
如何在Excel中一次打开多个链接 如何在Excel中使用VBA宏打开多个超链接
Excel 2019打印特定区域的3种方法图解教程
Excel表格怎么算乘法
如何在Excel单元格中快速输入“√ 勾”?
?Excel如何去除自动出现的人民币符号
扫码关注
- 专注IT行业,10年IT行业经验

