用VB如何从excel提取数据到word文档中
读写EXCEL表:1、在工程中引用Microsoft Excel类型库: 从"工程"菜单中选择"引用"栏;选择Microsoft Excel 12.0 Object Library(EXCEL2007),然后选择"确定"。
表示在工程中要引用EXCEL类型库。
2、在通用对象的声明过程中定义EXCEL对象: Dim xlApp As Excel.Application Dim xlBook As Excel.WorkBook Dim xlSheet As Excel.Worksheet 3、在程序中操作EXCEL表常用命令: Set xlApp = CreateObject("Excel.Application") '创建EXCEL对象 Set xlBook = xlApp.Workbooks.Open("文件名") '打开已经存在的EXCEL工件簿文件 Set xlBook = xlApp.Workbooks.Add("文件名") '创建新的EXCEL工件簿文件 xlApp.Visible = True '设置EXCEL对象可见(或不可见) Set xlSheet = xlBook.Worksheets("表名") '设置活动工作表 for i=1 to 100for j=1 to 50numArr(j,i)=xlSheet.Cells(j, i) '......................................nextnextxlBook.Close (True) '关闭工作簿 xlApp.Quit '结束EXCEL对象 Set xlApp = Nothing '释放xlApp对象张志晨...
VB2005如何把数据输出成为WORD或者Excel报表
用API函数ShellExecute VB声明 Declare Function ShellExecute Lib "shell32.dll" Alias "ShellExecuteA" (ByVal hwnd As Long, ByVal lpOperation As String, ByVal lpFile As String, ByVal lpParameters As String, ByVal lpDirectory As String, ByVal nShowCmd As Long) As Long 说明 查找与指定文件关联在一起的程序的文件名。
关联的方式要么是运行程序,要么是打印文件。
可用Windows注册表编辑器将特定的文件类型同应用程序关联起来。
例如,扩展名为.TXT的文本文件通常与Windows记事本(NOTEPAD.EXE)关联到一起。
如在文件管理器中双击含.TXT扩展名的一个文件,就会自行启动记事本程序,并在其中载入文本文件;或者将指定的文件打印出来 返回值 Long,大于32表示成功 参数表 : 参数 类型及说明 hwnd Long,指定一个窗口的句柄,有些时候,Windows程序有必要在创建自己的主窗口前显示一个消息框。
如果发生这种情况,由这个参数指定的窗口就会作为消息框的父窗口使用。
在VB环境中,通常将活动窗体的窗口句柄作为这个参数使用 lpOperation String,指定字串“Open”来打开lpFlie文档;或指定“Print”来打印它。
也可设为vbNullString,表示默认为“Open” lpFile String,想用关联的程序打印或打开的一个程序名或文件名 lpParameters String,如lpFile是一个可执行文件,则这个字串包含了传递给执行程序的参数。
如lpFile引用的是一个文档文件,或者不需要使用参数,则设为vbNullString lpDirectory String,想使用的默认路径完整路径 nShowCmd Long,定义了如何显示启动程序的常数值。
注解 这个函数的说明在MSDN里是这样的:Opens or prints a specified file VB是常用的应用软件开发工具之一,由于VB的报表功能有限,而且一但报表格式发生变化,就得相应修改程序,给应用软件的维护工作带来极大的不便。
因此有很多程序员现在已经充分利用EXECL的强大报表功来实现报表功能。
但由于VB与EXCEL由于分别属于不同的应用系统,如何把它们有机地结合在一起,是一个值得我们研究的课题。
一、 VB读写EXCEL表: VB本身提自动化功能可以读写EXCEL表,其方法如下: 1、在工程中引用Microsoft Excel类型库: 从"工程"菜单中选择"引用"栏;选择Microsoft Excel 9.0 Object Library(EXCEL2000),然后选择"确定"。
表示在工程中要引用EXCEL类型库。
2、在通用对象的声明过程中定义EXCEL对象: Dim xlApp As Excel.Application Dim xlBook As Excel.WorkBook Dim xlSheet As Excel.Worksheet 3、在程序中操作EXCEL表常用命令: Set xlApp = CreateObject("Excel.Application") '创建EXCEL对象 Set xlBook = xlApp.Workbooks.Open("文件名") '打开已经存在的EXCEL工件簿文件 xlApp.Visible = True '设置EXCEL对象可见(或不可见) Set xlSheet = xlBook.Worksheets("表名") '设置活动工作表 xlSheet.Cells(row, col) =值 '给单元格(row,col)赋值 xlSheet.PrintOut '打印工作表 xlBook.Close (True) '关闭工作簿 xlApp.Quit '结束EXCEL对象 Set xlApp = Nothing '释放xlApp对象 xlBook.RunAutoMacros (xlAutoOpen) '运行EXCEL启动宏 xlBook.RunAutoMacros (xlAutoClose) '运行EXCEL关闭宏 4、在运用以上VB命令操作EXCEL表时,除非设置EXCEL对象不可见,否则VB程序可继续执行其它操作,也能够关闭EXCEL,同时也可对EXCEL进行操作。
但在EXCEL操作过程中关闭EXCEL对象时,VB程序无法知道,如果此时使用EXCEL对象,则VB程序会产生自动化错误。
形成VB程序无法完全控制EXCEL的状况,使得VB与EXCEL脱节。
二、 EXCEL的宏功能: EXCEL提供一个Visual Basic编辑器,打开Visual Basic编辑器,其中有一工程属性窗口,点击右键菜单的"插入模块",则增加一个"模块1",在此模块中可以运用Visual Basic语言编写函数和过程并称之为宏。
其中,EXCEL有两个自动宏:一个是启动宏(Sub Auto_Open()),另一个是关闭宏(Sub Auto_Close())。
它们的特性是:当用EXCEL打含有启动宏的工簿时,就会自动运行启动宏,同理,当关闭含有关闭宏的工作簿时就会自动运行关闭宏。
但是通过VB的自动化功能来调用EXCEL工作表时,启动宏和关闭宏不会自动运行,而需要在VB中通过命令xlBook.RunAutoMacros (xlAutoOpen)和xlBook.RunAutoMacros (xlAutoClose) 来运行启动宏和关闭宏。
三、 VB与EXCEL的相互勾通: 充分利用EXCEL的启动宏和关闭宏,可以实现VB与EXCEL的相互勾通,其方法如下: 在EXCEL的启动宏中加入一段程序,其功能是在磁盘中写入一个标志文件,同时在关闭宏中加入一段删除此标志文件的程序。
VB程序在执行时通过判断此标志文件存在与否来判断EXCEL是否打开,如果此标志文件存在,表明EXCEL对象正在运行,应该禁止其它程序的运行。
如果此标志文件不存在,表明EXCEL对象已被用户关闭,此时如果要使用EXCEL对象运行,必须重新创建EXCEL对象。
四、举例: 1、在VB中,建立一个FORM,在其上放置两个命令按钮,将Command1的Caption属性改...
vb.net 求将数据导出到excel 或word源码
首先假设你已经有的表的名字为sheet1,保存的EXCEL文件名为A.XLS.(表中第一行有表头,否则第一行会忽略掉的)那么就现在就在word里设计好一张表格,也就是你要打印的页面,至于名字等后面先空着,等下让它自己去连A.XLS。
做到这里了,就开始来邮件合并吧:1,word里做好后,你在工具栏那点右键,选上邮件合并,那么邮件合并的工具栏就会显示了。
2.在出来的的邮件合并工具栏中选第二个工具“打开数据源”,找到你的A.XLS文件,确定后选择你的表名:sheet1。
3.把光标移到姓名后面,点邮件合并工具栏中第五个工具“插入域”,选上表头的名字,如:姓名。
后面以此类推!4,到这里就基本完成了,你可以选邮件合并工具栏中倒数第四个“合并到新文件”看看合并效果,理想的话可以直接打印了!以上我是在EXCEL2002版本中运行通过的,其他版本基本一样的!
【怎样用程序提取数据】请问如何用vb提取excel表格中的数据有一张...
如何实现VB与EXCEL的无缝连接 VB是常用的应用软件开发工具之一,由于VB的报表功能有限,而且一但报表格式发生变化,就得相应修改程序,给应用软件的维护工作带来极大的不便。
因此有很多程序员现在已经充分利用EXECL的强大报表功来实现报表功能。
但由于VB与EXCEL由于分别属于不同的应用系统,如何把它们有机地结合在一起,是一个值得我们研究的课题。
一、 VB读写EXCEL表: VB本身提自动化功能可以读写EXCEL表,其方法如下: 1、在工程中引用Microsoft Excel类型库: 从"工程"菜单中选择"引用"栏;选择Microsoft Excel 9.0 Object Library(EXCEL2000),然后选择"确定"。
表示在工程中要引用EXCEL类型库。
2、在通用对象的声明过程中定义EXCEL对象:Dim xlApp As Excel.ApplicationDim xlBook As Excel.WorkBookDim xlSheet As Excel.Worksheet 3、在程序中操作EXCEL表常用命令:Set xlApp = CreateObject("Excel.Application") '创建EXCEL对象Set xlBook = xlApp.Workbooks.Open("文件名") '打开已经存在的EXCEL工件簿文件xlApp.Visible = True '设置EXCEL对象可见(或不可见)Set xlSheet = xlBook.Worksheets("表名") '设置活动工作表xlSheet.Cells(row, col) =值 '给单元格(row,col)赋值xlSheet.PrintOut '打印工作表xlBook.Close (True) '关闭工作簿xlApp.Quit '结束EXCEL对象Set xlApp = Nothing '释放xlApp对象xlBook.RunAutoMacros (xlAutoOpen) '运行EXCEL启动宏xlBook.RunAutoMacros (xlAutoClose) '运行EXCEL关闭宏 4、在运用以上VB命令操作EXCEL表时,除非设置EXCEL对象不可见,否则VB程序可继续执行其它操作,也能够关闭EXCEL,同时也可对EXCEL进行操作。
但在EXCEL操作过程中关闭EXCEL对象时,VB程序无法知道,如果此时使用EXCEL对象,则VB程序会产生自动化错误。
形成VB程序无法完全控制EXCEL的状况,使得VB与EXCEL脱节。
二、 EXCEL的宏功能: EXCEL提供一个Visual Basic编辑器,打开Visual Basic编辑器,其中有一工程属性窗口,点击右键菜单的"插入模块",则增加一个"模块1",在此模块中可以运用Visual Basic语言编写函数和过程并称之为宏。
其中,EXCEL有两个自动宏:一个是启动宏(Sub Auto_Open()),另一个是关闭宏(Sub Auto_Close())。
它们的特性是:当用EXCEL打含有启动宏的工簿时,就会自动运行启动宏,同理,当关闭含有关闭宏的工作簿时就会自动运行关闭宏。
但是通过VB的自动化功能来调用EXCEL工作表时,启动宏和关闭宏不会自动运行,而需要在VB中通过命令xlBook.RunAutoMacros (xlAutoOpen)和xlBook.RunAutoMacros (xlAutoClose) 来运行启动宏和关闭宏。
三、 VB与EXCEL的相互勾通: 充分利用EXCEL的启动宏和关闭宏,可以实现VB与EXCEL的相互勾通,其方法如下: 在EXCEL的启动宏中加入一段程序,其功能是在磁盘中写入一个标志文件,同时在关闭宏中加入一段删除此标志文件的程序。
VB程序在执行时通过判断此标志文件存在与否来判断EXCEL是否打开,如果此标志文件存在,表明EXCEL对象正在运行,应该禁止其它程序的运行。
如果此标志文件不存在,表明EXCEL对象已被用户关闭,此时如果要使用EXCEL对象运行,必须重新创建EXCEL对象。
四、举例: 1、在VB中,建立一个FORM,在其上放置两个命令按钮,将Command1的Caption属性改为EXCEL,Command2的Caption属性改为End。
然后在其中输入如下程序:Dim xlApp As Excel.Application '定义EXCEL类 Dim xlBook As Excel.Workbook '定义工件簿类Dim xlsheet As Excel.Worksheet '定义工作表类 Private Sub Command1_Click() '打开EXCEL过程 If Dir("D:\temp\excel.bz") = "" Then '判断EXCEL是否打开 Set xlApp = CreateObject("Excel.Application") '创建EXCEL应用类 xlApp.Visible = True '设置EXCEL可见 Set xlBook = xlApp.Workbooks.Open("D:\temp\bb.xls") '打开EXCEL工作簿 Set xlsheet = xlBook.Worksheets(1) '打开EXCEL工作表 xlsheet.Activate '激活工作表 xlsheet.Cells(1, 1) = "abc" '给单元格1行驶列赋值 xlBook.RunAutoMacros (xlAutoOpen) 运行EXCEL中的启动宏 Else MsgBox ("EXCEL已打开") End IfEnd SubPrivate Sub Command2_Click() If Dir("D:\temp\excel.bz") "" Then '由VB关闭EXCEL xlBook.RunAutoMacros (xlAutoClose) '执行EXCEL关闭宏 xlBook.Close (True) '关闭EXCEL工作簿 xlApp.Quit '关闭EXCEL End If Set xlApp = Nothing '释放EXCEL对象 EndEnd Sub 2、在D盘根目录上建立一个名为Temp的子目录,在Temp目录下建立一个名为"bb.xls"的EXCEL文件。
3、在"bb.xls"中打开Visual Basic编辑器,在工程窗口中点鼠标键选择插入模块,在模块中输入入下程序存盘:Sub auto_open() Open "d:\temp\excel.bz" For Output As #1 '写标志文件 Close #1End SubSub auto_close() Kill "d:\temp\excel.bz" '删除标志文件End Sub 4、运行VB程序,点击EXCEL按钮可以打开EXCEL系统,打开EXCEL系统后,...
VB将数据导出到word的问题
Private Sub Command1_Click()Dim wd As New Word.Applicationwd.Documents.Add DocumentType:=wdNewBlankDocumentWith wd.Selection.Font.Spacing = 2.ParagraphFormat.Alignment = wdAlignParagraphCenter.Font.Size = 16.Font.Name = "宋体".Font.Bold = True.ParagraphFormat.LineSpacingRule = wdLineSpaceSingle.Font.Spacing = 0.TypeText label1.Caption.Font.Bold = False.TypeParagraph.ParagraphFormat.Alignment = wdAlignParagraphJustify.Font.Size = 10.TypeText text1.Text & text2.Textwd.ActiveDocument.Tables.Add Range:=wd.Selection.Range, NumRows:=mshflexgrid1.Rows, NumColumns _:=10, DefaultTableBehavior:=wdWord9TableBehavior, AutoFitBehavior:=wdAutoFitFixedFor i = 1 To mshflexgrid1.RowsFor j = 1 To 10.Tables(1).Cell(i, j).Range.Text = mshflexgrid1.textmatrix(i - 1, j - 1)Next jNext i.EndKey Unit:=wdStory.Font.Color = wdColorRed.TypeText text3.Text & vbTab & vbTab & vbTab & text4.Text.TypeParagraph.Font.Color = wdColorAutomatic.TypeText text5.Text & vbTab & vbTab & vbTab & text6.TextEnd Withwd.Visible = Truewd.ShowMeSet wd = NothingEnd Sub
如何将EXCEL表中的数据传入VB将EXCEL(成绩表)的数据全
总体来说,有三个办法. 你要经过的程序有三个:Excel、VB和Access。
你的最终目的是把表导进去,这样,三个环节各有各的方法。
第一种:Excel宏 Sub AddToAccess() ' ' AddToAccess Macro ' On Error GoTo Error1 Dim conn As New ADODB.Connection conn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=F:\a\ b" Dim sql As String, i As Integer ''创建表'失败,不支持SQL语句 'sql = "create table users(" & Cells(1, 1) & " char(20)," & Cells(1, 2) & " char(20))" 'conn.Execute sql For i = 2 To 3 '表中数据到第三行截止 sql = "insert into users values('" & Cells(i, 1) & "','" & Cells(i, 2) & "')" conn.Execute sql Next MsgBox "成功!" Exit Sub Error1: MsgBox "错误" & vbCrLf & Err.Description Err.Clear End Sub 相关表已附件,这种较为简便,缺点是不能随时使用,因为系统对宏有限制,不能随意使用,不知道怎么改,望高手指教。
第二种:VB内 该方法楼上已介绍,不再复述。
有时间再写,今天累得慌。
第三种:Access 你会发现Access内有导入导出的工具,选择插入表,然后导入表,之后选择类型为xls,然后是向导。
自己应该会了吧?
用VB将动态数据逐个写入EXCEL的单元格,会将原来的表格覆盖怎? ...
循环 With wdRange.Find ;查找 .Replacement.Text = key(i) & IIf(i = 1, Cells(1;abcdefg" '要替换的数据 key(2) = ".Format = False .MatchCase = False .MatchWholeWord = False .Value;捕捉错误 Dim oSt As Range, wdDoc As Word,双击后输入下列代码.Range myPath = ThisWorkbook.Path & ".Wrap = wdFindContinue .doc Set wdDoc = GetObject(myPath) '打开word Dim key(2) '替换 .Forward = True .Execute Replace将excel和word放在同一目录下.ScreenUpdating = True '开启屏幕刷新End Sub 经测试,已经达到楼主要求;\2.doc"定义word文件路径,名字自己修改.ScreenUpdating = False '关闭屏幕刷新 On Error Resume Next '.Text = key(i) '定义一下数组, key(1) = "hijklmn" Set wdRange = wdDoc.Content '将word的文档内容赋予wdrange For i = 1 To 2 '.MatchAllWordForms = False End With wdRange.Find.MatchByte = True .MatchWildcards = False :=wdReplaceAll '全部替换 Next wdDoc.Save '保存word wdDoc.Close '关闭word Set wdDoc = Nothing Application, 1),在excel中建立按钮.MatchSoundsLike = False .Document, wdRange As Word; ', Cells(5, 2).Value) ',我设定为2:Private Sub CommandButton1_Click() Application...
转载请注明出处51数据库 » vb将excel数据到word
狂人1日妓