怎么用VB打开word/EXCEL

作者&投稿:苑雷 (若有异议请与网页底部的电邮联系)
如何在vb中打开Excel~

Visual Basic开发工具模式可以直接从Excel表格中进入,不需要另外打开。
具体步骤:
1、在电脑上桌面上找到Excel表格图标,双击打开。

2、打开Excel软件后,点击左上角按钮。

3、点击后会弹出一个菜单,在菜单中点击Excel选项按钮。

4、然后在弹出的对话框中勾选自定义功能区中的“开发工具”。

5、然后点击右下方确定按钮。

6、点击确定后,会返回Excel页面。

7、然后在Excel上方的导航栏中点击开发工具按钮。

8、然后在开发工具页面,点击Visual Basic选项。

9、点击后就会进入Visual Basic开发模式。

10、点击左侧导航栏中的Excel中的sheet表格,就可以在Visual Basic中打开了。

给你两个小例子。一、控制WordPrivate Sub Command1_Click()
Dim wdApp As Application
Dim wdDoc As Word.Document
Dim OpenFile As String
Dlg1.ShowOpen
OpenFile = Dlg1.FileName
Set wdApp = CreateObject("Word.application")
Set wdDoc = wdApp.Documents.Open(OpenFile)
For i = 1 To wdDoc.Characters.Count
Text1.Text = Text1.Text + wdDoc.Characters(i)
Next
wdDoc.Close
wdApp.Quit
Set wdDoc = Nothing
Set wdApp = Nothing
End Sub 二、操作ExcelPrivate Sub Form_Click()
'在“工程/引用”中选择Microsoft Excel9.0 Object LibraryDim xlApp As Excel.Application '定义EXCEL类
Dim xlBook As Excel.Workbook '定义工作簿类
Dim xlSheet As Excel.Worksheet '定义工作表类
'激活EXCEL应用程序
Set xlApp = CreateObject("Excel.Application")
'打开工作簿
Dim Filename As String
dlg1.ShowOpen
Filename = dlg1.Filename
Set xlBook = xlApp.Workbooks.Open(Filename)
Set xlSheet = xlBook.Worksheets(1)
Text1.Text = xlSheet.Range("A1").Value '关闭工作簿和EXCEL应用程序
xlBook.Close
xlApp.Quit
Set xlSheet = Nothing
Set xlBook = Nothing
Set xlApp = NothingEnd Sub

在VB应用程序中调用Excel2000

一、Excel对象模型

为了在VB应用程序中调用Excel,必须要了解Excel对象模型。Excel对象模型描述了Excel的理论结构,所提供的对象很多,其中最重要的对象,即涉及VB调用Excel最可能用到的对象有:

二、调用Excel

在VB应用程序中调用Excel,实质是将Excel作为一个外部对象来引用,由Excel对象模型提供能从VB应用程序内部来程序化操纵的对象以及相关的属性、方法和事件。

1、在VB工程中添加对Excel类型库的引用

为了能从VB应用程序中访问Excel丰富的内部资源,使Excel应用程序运行得更快,需要在VB工程中添加对Excel类型库的引用。具体步骤如下:

a)从VB5“工程”菜单中选择“引用”;

b) 在“引用”对话框中选择Excel类型库:"Microsoft Excel9.0 Object Library";

c)单击左边小方框,使之出现“√”符号;

d)按“确定”退出。

注:要想在VB应用程序中调用Excel,你的计算机系统中必须安装Excel。

2、引用Application对象

Application对象是Excel对象模型的顶层,表示整个Excel应用程序。在VB应用程序中调用Excel,就是使用Application对象的属性、方法和事件。为此,首先要声明对象变量:

Dim VBExcel As Object

或直接声明为Excel对象:

Dim VBExcel As Excel.Application

在声明对象变量之后,可用CreateObject函数或GetObject函数给变量赋值新的或已存在的Application对象引用。

a)用CreateObject函数生成新的对象引用:

Set VBExcel=CreateObject ("Excel.Application")

字符串“Excel.Application”是提供Excel应用程序的编程ID,这个变量引用Excel应用程序本身。

b)用GetO场ect函数打开已存在的对象引用:

Set AppExcel=GetObject("SAMP.XLS")

上面语句打开文件SAMP.XLS。

3、Application对象常用的属性、方法

属性、方法 方法
Visible属性 取True或False,表明Excel应用程序是否可见。
Left,Top属性 Excel窗口的位置;
Height, Width属性 Excel窗口的大小;
WindowState属性 指定窗口的状态,取:XIMaximized(最大化)X1 Minimized(最小化)x1 Normal(缺省)。
Quit方法 退出Microsoft Excel;
Calculate方法 重新计算所有打开的工作簿、工作表或单元格。
Evaluate方法 求值数学表达式并返回结果。

示例1:求值数学表达式:

Dim VBExcel As Object
Set VBExcel=CreateObject ("Excel.Application")
X=VBExcel. Evaluate ("3+5*(cos (1/log (99. 9)))")
三、使用Excel应用程序

如前所述,在VB应用程序中调用Excel应用程序,就是使用Application对象的属性、方法和事件。下面分类给出其中常用的属性和方法。

1、使用工作薄

Workbook对象代表Excel应用程序中当前打开的一个工作簿,包含在Workbooks集合中。可以通过Workbooks集合或表示当前活动工作簿的Active Workbook对象访问Workbook对象。

常用的方法有:

属性、方法 意义
Add方法 创建新的空白工作簿,并将其添加到集合中。
Open方法 打开工作簿。
Activate方法 激活工作簿,使指定工作簿变为活动工作簿,以便作为Active Workbook对象使用。
Save方法 按当前路径和名称保存现有工作簿(如是首次保存,则将其保存到缺省名称中,如BOOK1.XLS)。
SaveAs方法 首次保存工作簿或用另一名称保存工作簿。
Close方法 关闭工作簿。
PrintOut方法 打印工作簿,语法为:

PrintOut (from, To, Copies, Preview, Printer, ToFile, Collate)

可选参数:

From:打印的起始页号。如省略将从起始位置开始打印。
To:打印的终止页号。如省略将打印至最后一页。
Copies:要打印的份数。如省略将只打印一份。
Preview:如果为True则Excel打印指定对象之前进行打印预览。如果为False,或省略则立即打印该对象。
Printer:设置活动打印机的名称。
ToFile:如果为True则打印输出到文件。
Collate:如果为True则逐份打印每份副本。

下面语句将活动工作簿的2到5页打印3份:

ActiveWorkbook.PrintOut From:=2 To 5 Copies:=3

示例2:生成、保存、关闭工作簿

Dim VBExcel As Excel.Application
Set VBExcel== CreateObject("Excel.Application")
With VBExcel
.Workbooks.Add
With ActiveWorkbook
.Save As"C: \Temp \OUTPUT.XLS"
.Close
End With
.Quit
End With

2、使用工作表

Sheets集合表示工作簿中所有的工作表。可以通过Sheets集合来访问、激活、增加、更名和删除工作表。一个Worksheet对象代表一个工作表。

常用的属性、方法有:

属性、方法 意义
Worksheets属性 返回Sheets集合。
Name属性 工作表更名。
Add方法 创建新工作表并将其添加到工作簿中。
Select方法 选择工作表。
Copy方法 复制工作表。
Move方法 将指定工作表移到工作簿的另一位置。
Delete方法 删除指定工作表。
PrintOut方法 打印工作表。

示例3:将C盘工作簿中的工作表复制到A盘工作簿中:

Dim VBExcel As Excel.Application
Set VBExcel=CreateObject("Excel.Application")
With VBExcel
.Workbooks.Open "C:\Temp\OUTPUT.XLS"
.Workbooks.Open"A:\OUTPUT1.XLS"
.Workbooks("OUTPUT.XLS").Sheets ("Sales").Copy
.Workbooks("OUTPUT1.XLS)
.Workbooks("OUTPUT1.XLS").Save
.Workbooks("OUTPUT.XLS").Close
.Workbooks("OUTPUTI.XLS").Close
.Quit
End With

3、使用单元范围

Range对象代表工作表的某一单元格、某一行、某一列、某一选定区域或者某一三维区域。

常用的属性、方法有:

属性、方法 意义
Range属性 Range (arg)其中arg为A1--样式符号,表示单个单元格或单元格区域。
Cells属性 Cells (row, col )(其中row为行号,col为列号)表示单个单元格。
ColumnWidth属性 指定区域中所有列的列宽。
Rowl3eight属性 指定区域中所有行的行宽。
Value属性 指定区域中所有单元格的值(缺省属性)。
Formula属性 指定单元格的公式,由A1--样式引用。
Select方法 选择范围。
Copy方法 将范围的内容复制到剪贴板。
C1earContents方法 清除范围的内容。
Delete方法 删除指定单元范围。

4、使用图表

Chart对象代表工作簿中的图表。该图表既可为嵌人式图表(包含于ChartObject对象中)也可为分立的图表工作表。

常用方法有:

方法 意义

Add方法 新建图表工作表。返回Chart对象。
PrineOut方法 打印图表。
ChartWizard方法 修改给定图表的属性,其语法为:

ChartWizard(Source, Gallery, Format, P1otBy, CategoryLabels,
SeriesLabels, HasLegend, Title, CategoryTitle, ValueTitle, ExtraTitle)

其中:

Source:包含新图表的源数据的区域。如省略,将修改活动图表工作表或活动工作表中处于选定状态的嵌人式图表。

Gallery:图表类型。其值可为下列常量之一:xlArea, x1Bar, xlColumn, xlLine, x1Pie, xlRadar,x1XYScatter, xlCombination, x13DArea, x13DBar、x13DColumn, x13DLine, x13DPie、x13 DSurface、xlDoughnut或xlDefaultAutoFormat。

Format:内置自动套用格式的编号。如省略,将选择默认值。

P1otBy:指定系列中的数据是来自行(xlRows)还是列(xlColumns)。

CategoryLabels:表示包含分类标志的源区域内行数或列数的整数。

SeriesLabels:表示包含系列标志的源区域内行数或列数的整数。

HasLegend:若指定True,则图表将具有图例。

Title:图表标题文字。

CategoryTitle:分类轴标题文字。

ValueTitle:数值轴标题文字。

ExtraTitle:三维图表的系列轴标题,或二维图表的第二数值轴标题。

可组合使用Add方法和ChartWizard方法,以创建包含工作表中数据的图表工作表。下例基于工作表“Sheetl”中单元格区域“A1:A20”中的数据生成新的折线图并打印。

With Charts.Add
.ChartWizard source:=Worksheets ("sheet1").Range ("a1:a20"),gallery:=xlLine, title:=“折线图表”
.Printout
End With

5、使用Excel工作表函数

在VB语句中可使用大部分的Excel工作表函数,可通过WorksheetFunction对象调用Excel工作表函数。下面的Sub过程用Min工作表函数求出指定区域中单元格的最小值,并通过消息框显示结果值。

Sub UseFunction()
Dim myRange As Range
Set myRange=Worksheets ("Sheet1").Range("B2:F10")
answer=Application.WorksheetFunction.Min(myRange)
MsgBox answer
End Sub

如果使用以区域引用为参数的工作表函数,必须指定一个Range对象。如可用Match工作表函数对A1:A10区域的所有单元格进行搜索。

Sub FindFirst()
my Var=Application.WorksheetFunction.Match (9, Worksheets( 1).Range("A1:A10"),0)
MsgBox myVar
End Sub

要在单元格中插人工作表函数,可将该函数指定为对应于Range对象的Formula属性值。在以下示例中,将当前工作簿Sheetl内A1:B3区域的Formula属性指定为RAND工作表函数(此函数产生二个随机数)。

Sub InsertFormula()
Worksheets ("Sheet1" ).Range("A1:B3").Formula="RAND()"
End Sub

以上简要介绍了Excel对象模型中部分对象及其属性和方法,更详细的信息可参阅Excel 2000帮助中的“Microsoft Excel Visual Basic参考”一节的内容。实际上,Microsoft Office家族的Word,PowerPoint, Access和Project等应用程序都可以在VB应用程序中调用,其原理和步骤完全相同,只是其对象模型有所不同而已

……
……

恐怕难以完成你的要求。

要知道在VB中doc和xls文件只能调用word和excel来打开

VB是不能独立读取这些文件的。

除非你对doc和xls文件格式有相当了解

达到了wps2005工程师的水平

xls文件到还能通过其他方法来获取其中的数据

而且只能获得数据,

格式信息一定要通过引用office对象来取得

doc文件就更不要多想了

肯定不行。

但后台打开文件不让软件界面显示是完全可以做到的。

事实是

当你引用了office对象

除非专门加入Visible = True 命令显示word或excel界面

不然软件的界面是不会显示的。

估计你的要求很难实现了。VB本身不能独立读取这些文件,其次,即便你调用了WORD,也只是打开了它的第一页的内容,后面的内容是无法继续打开的。而且VB无法判断你要打开的文章有多少段落,更别提什么段落的字体,字号 是否有下划线等信息了

在vb的"工程"->"引用" 中引用word 或excel
dim excel as object
dim workbook as object
dim worksheet as object

Set excel = CreateObject("excel.application")
Set workbook = excel.Workbooks.Open(App.Path & "\temp.xls")
Set worksheet = workbook.ActiveSheet
excel.Visible = True

Dim word As Object
Dim documents As Object
Private Sub Command1_Click()
Set word = CreateObject("word.application")
Set documents = word.documents.Open("c:\temp.doc")
word.Visible = True
End Sub

Private Sub Command1_Click()
Dim word As Object
Dim xlApp As Object
Dim msword As Object
Dim xlBook As Object
Dim xlSheet As Object

Set xlApp = CreateObject("Excel.Application")
xlApp.Visible = True
Set xlBook = xlApp.Workbooks.Add
Set xlSheet = xlBook.Worksheets(1)

Set msword = CreateObject("word.basic")
Set word = CreateObject("word.application")
word.Visible = True
msword.filenewdefault '建立一个WORD新文档
msword.MsgBox "正在建立MS_WORD报表,请稍候.......", "", -1
msword.leftpara
msword.screenupdating 0
msword.tableinserttable , 1, 1, , , 16, 167
msword.StartOfDocument
msword.Insert ""
msword.tabledeleterow
msword.StartOfDocument
msword.tableheadings 1
msword.centerpara
msword.screenrefresh
msword.screenupdating 1
msword.MsgBox "结束", "", -1
End Sub
绝对管用!!!!!!!!!!!!!!!!!!!!

设计一个程序,用VB打开WORD文档,并对其进行修改保存?
答:首先你要在VB的“工程”->“引用”中引用“Microsoft Word 9.0 Object LibraryPrivate Sub Command1_Click()'打开指定的Word文件 Dim wdApp As Word.Application Dim aDoc As Document Set wdApp = New Word.Application Set aDoc = wdApp.Documents.Open(FileName:="你要打开的Word文件路径及文件...

vb调用wordvb调用wordapplication
答:即word文字处理系统界面Set Word文档 = Word文字处理系统界面.Documents.Open(文件路径)Set Word文档文本 = Word文字处理系统界面.SelectionWord文档文本.WholeStoryWord文档文本.Copy剪切板文本 = Clipboard.GetText(vbCFText)'放到text1中Text1.Text = 剪切板文本'Clipboard.SetData TempWord文档.Close '关...

VB打开word
答:1、选中图片;2、单击图片工具格式---文字环绕---浮于文字上方即可,如图所示。

如何用VB打开一WORD文档?
答:用左键点击所要打开的word文件,然后点击右键,会出现一个菜单,然后选择复制。这样就能把那个word的内容复制出来了。

急求“vb中如何打开一个通过文本框输入的WORD文件”程序代码
答:归纳起来3种办法:使用webbrowser,或者将word文档另存为rtf文件,使用vb的richtext控件打开,缺点:文档保持不了原来的格式和部分内容 使用vb操作word,或使用第三方库,缺点:需要目标机器上有相应版本的word,运行速度很慢 自己解析word的doc文件,自己自定义控件,运行速度最快,不受目标机器环境限制,...

用VB打开一个已存在的word文档并向其中插入指定文本
答:Set oDocument = oWord.Documents.Open("e:\test1.doc")'要打开的文件名 ' End If oWord.Visible = True '如果不想看见WORD窗口,可以设为false '将text插入到最后 oDocument.Paragraphs.Last.Range.InsertAfter Text1.Text OpenDocument = 1 GoTo ExitOpen ErrOpen:OpenDocument = 0 ExitOpen:...

如何用VB打开word2007,例如桌面有个word2007文件,如何用VB打开
答:'先将菜单中“工程-引用”中的Microsoft Word…选中 Private Sub Command1_Click()Dim wordApp As New Word.Application Dim wordDoc As New Word.Document Set wordApp = CreateObject("Word.Application")wordApp.Visible = True Set wordDoc = wordApp.Documents.Open("C:\2.doc")End Sub ...

使用VB,如何打开Word,Excel,Text,Exe,PDF,GIF 。。。
答:lpOperation String,指定字串“Open”来打开lpFlie文档;或指定“Print”来打印它。也可设为vbNullString,表示默认为“Open”lpFile String,想用关联的程序打印或打开的一个程序名或文件名 lpParameters String,如lpFile是一个可执行文件,则这个字串包含了传递给执行程序的参数。如lpFile引用的是一个...

vb如何打开外部的word文件,不用再程序内打开。只要一个链接类似的调用of...
答:新建一个vb。工程、引用、microsoft word 11.0 object library 如果是2007版的word就是12.0,引用这个word就行哪个版都一样 然后拖拽一个command1 敲入如下代码 Private Sub Command1_Click()'---以下是生成word文档。Dim Wapp2 As New Word.Application Dim Wdoc2 As New Word.Document Dim Opar...

怎么用VB打开word/EXCEL
答:a)用CreateObject函数生成新的对象引用:Set VBExcel=CreateObject ("Excel.Application") 字符串“Excel.Application”是提供Excel应用程序的编程ID,这个变量引用Excel应用程序本身。 b)用GetO场ect函数打开已存在的对象引用:Set AppExcel=GetObject("SAMP.XLS") 上面语句打开文件SAMP.XLS。 3、Application对象常用的属...