VB与Excel的数据交换
VB与Excel的数据交换
第11 章VB 与Excel 的数据交换Excel 是目前非常流行的电子表格软件,很多人都习惯于在EXCEL中处理数据,并在Excel 中完成报表输出等功能,但Excel 的数据处理功能相对较弱,而VB具有强大的数据处理功能,但报表输出功能相对较弱。
本章以实例的形式介绍VB 如何从Excel 中获得数据,再将处理后的数据保存到Excel 工作表中,并调用Excel 中的VBA指令对排版,生成数据报表。
VB 中Excel 的启动与关闭11.1.1 Excel 对象库引用在VB 中调用Excel ,首先需要打开VB 编程环境“工程”菜单中的“引用”项目,并选取项目中的“ Microsoft Excel object library ”( Excel 版本不同,这个选项中的的版本号可能不一样) 。
引用Excel 对象库后,对编写代码会带来很多便利。
11.1.2 Excel 对象声明EXCEL 是以层次结构组织对象的,其对象模型中含有许多不同的对象元素。
编程过程中主要用到以下4 个层次的对象。
1 .Application 对象,即Excel 程序本身;2 .WorkBook 对象,即Excel 的工作簿文件对象;3 .WorkSheets 对象,表示的是Excel 的工作表对象集;例如:worksheets(1) 表示第一个工作表。
4.Cells 、Range、Rows、Columns 对象,分别表示Excel 工作表中的单元格对象集、区域对象、行对象集、列对象集。
例如:Cells(3 ,5)表示第 3 行第 5 列的那个单元格Range("C5")表示第3 行第5 列的那个单元格Range("A1:C5")表示从A1单元格到C5 单元格的矩形区域表示第1 行Rows(1)表示第1 行Range("1:1")表示第1 到10 行的区域Range("1:10")表示第1 列Columns(1)表示第1 列Range("A:A")Range("A:D")表示从第A 到D 列11.1.3 VB 中Excel 的启动与关闭例11-1 新建立一个VB 的工程,在窗体上添加2 个命令按钮(Command1和Command)2,2 个按钮的Caption 分别为“启动Excel ”和“关闭Excel ”,输入以下代码即可。
VB对excel操作的方法总汇教程
VB对excel操作的方法总汇教程用VB操作excel方法汇总Private Sub Command1_Click()Dim i As LongDim j As LongDim objExl As Excel.Application '声明对象变量Me.MousePointer = 11 '改变鼠标样式Set objExl = New Excel.Application '初始化对象变量objExl.SheetsInNewWorkbook = 1 '将新建的工作薄数量设为1 objExl.Workbooks.Add '增加一个工作薄objExl.Sheets(objExl.Sheets.Count).Name = "book1" '修改工作薄名称objExl.Sheets.Add , objExl.Sheets("book1") '增加第二个工作薄在第一个之后objExl.Sheets(objExl.Sheets.Count).Name = "book2"objExl.Sheets.Add , objExl.Sheets("book2") '增加第三个工作薄在第二个之后objExl.Sheets(objExl.Sheets.Count).Name = "book3"objExl.Sheets("book1").Select '选中工作薄<book1>For i = 1 To 50 '循环写入数据For j = 1 To 5If i = 1 ThenobjExl.Selection.NumberFormatLocal = "@" '设置格式为文本objExl.Cells(i, j) = " E " & i & jElseobjExl.Cells(i, j) = i & jEnd IfNextNextobjExl.Rows("1:1").Select '选中第一行objExl.Selection.Font.Bold = True '设为粗体objExl.Selection.Font.Size = 24 '设置字体大小objExl.Cells.EntireColumn.AutoFit '自动调整列宽objExl.ActiveWindow.SplitRow = 1 '拆分第一行objExl.ActiveWindow.SplitColumn = 0 '拆分列objExl.ActiveWindow.FreezePanes = True '固定拆分objExl.ActiveSheet.PageSetup.PrintTitleRows = "$11" '设置打印固定行objExl.ActiveSheet.PageSetup.PrintTitleColumns = "" '打印标题objExl.ActiveSheet.PageSetup.RightFooter = "打印时间: " & _ Format(Now, "yyyy年mm月dd日 hh:MM:ss")objExl.ActiveWindow.View = xlPageBreakPreview '设置显示方式objExl.ActiveWindow.Zoom = 100 '设置显示大小'给工作表加密码objExl.ActiveSheet.Protect "123", DrawingObjects:=True, _Contents:=True, Scenarios:=TrueobjExl.Application.IgnoreRemoteRequests = FalseobjExl.Visible = True '使EXCEL可见objExl.Application.WindowState = xlMaximized 'EXCEL的显示方式为最大化objExl.ActiveWindow.WindowState = xlMaximized '工作薄显示方式为最大化objExl.SheetsInNewWorkbook = 3 '将默认新工作薄数量改回3个Set objExl = Nothing '清除对象Me.MousePointer = 0 '修改鼠标Exit SubEnd Sub全面控制 Excel首先创建 Excel 对象,使用ComObj:Dim ExcelID as Excel.ApplicationSet ExcelID as new Excel.Application1) 显示当前窗口:ExcelID.Visible :=True;2) 更改Excel 标题栏:ExcelID.Caption := '应用程序调用 MicrosoftExcel';3) 添加新工作簿:ExcelID.WorkBooks.Add;4) 打开已存在的工作簿:ExcelID.WorkBooks.Open( 'C:\Excel\Demo.xls' );5) 设置第2个工作表为活动工作表:ExcelID.WorkSheets[2].Activate;或ExcelID.WorkSheets[ 'Sheet2' ].Activate;6) 给单元格赋值:ExcelID.Cells[1,4].Value := '第一行第四列';7) 设置指定列的宽度(单位:字符个数),以第一列为例:ExcelID.ActiveSheet.Columns[1].Colu mnsWidth := 5;8) 设置指定行的高度(单位:磅)(1磅=0.035厘米),以第二行为例:ExcelID.ActiveSheet.Rows[2].RowHeig ht := 1/0.035; // 1厘米9) 在第8行之前插入分页符:ExcelID.WorkSheets[1].Rows[8].PageB reak := 1;10) 在第8列之前删除分页符:ExcelID.ActiveSheet.Columns[4].Page Break := 0;11) 指定边框线宽度:ExcelID.ActiveSheet.Range[ 'B34' ].Bor ders[2].Weight := 3;1-左 2-右 3-顶 4-底 5-斜( \ ) 6-斜( / )12) 清除第一行第四列单元格公式:ExcelID.ActiveSheet.Cells[1,4].ClearConten ts;13) 设置第一行字体属性:ExcelID.ActiveSheet.Rows[1].Font.Na me := '隶书';ExcelID.ActiveSheet.Rows[1].Font.Colo r := clBlue;ExcelID.ActiveSheet.Rows[1].Font.Bold := True;ExcelID.ActiveSheet.Rows[1].Font.Und erLine := True;14) 进行页面设置:a.页眉:ExcelID.ActiveSheet.PageSetup.CenterHea der := '报表演示';b.页脚:ExcelID.ActiveSheet.PageSetup.CenterFoo ter := '第&页';c.页眉到顶端边距2cm:ExcelID.ActiveSheet.PageSetup.HeaderMa rgin := 2/0.035;d.页脚到底端边距3cm:ExcelID.ActiveSheet.PageSetup.HeaderMa rgin := 3/0.035;e.顶边距2cm:ExcelID.ActiveSheet.PageSetup.T opMargin := 2/0.035;f.底边距2cm:ExcelID.ActiveSheet.PageSetup.BottomMa rgin := 2/0.035;g.左边距2cm:ExcelID.ActiveSheet.PageSetup.LeftMargin := 2/0.035;h.右边距2cm:ExcelID.ActiveSheet.PageSetup.RightMarg in := 2/0.035;i.页面水平居中:ExcelID.ActiveSheet.PageSetup.CenterHori zontally := 2/0.035;j.页面垂直居中:ExcelID.ActiveSheet.PageSetup.CenterVert ically := 2/0.035;k.打印单元格网线:ExcelID.ActiveSheet.PageSetup.PrintGridLi nes := True;15) 拷贝操作:a.拷贝整个工作表:ed.Range.Copy;b.拷贝指定区域:ExcelID.ActiveSheet.Range[ 'A1:E2' ].Copy;c.从A1位置开始粘贴:ExcelID.ActiveSheet.Range.[ 'A1' ].PasteSp ecial;d.从文件尾部开始粘贴:ExcelID.ActiveSheet.Range.PasteSpecial;16) 插入一行或一列:a. ExcelID.ActiveSheet.Rows[2].Insert;b.ExcelID.ActiveSheet.Columns[1].Insert;17) 删除一行或一列:a. ExcelID.ActiveSheet.Rows[2].Delete;b.ExcelID.ActiveSheet.Columns[1].Delete;18) 打印预览工作表:ExcelID.ActiveSheet.PrintPreview;19) 打印输出工作表:ExcelID.ActiveSheet.PrintOut;20) 工作表保存:If not ExcelID.ActiveWorkBook.Saved thenExcelID.ActiveSheet.PrintPreviewEnd if21) 工作表另存为:ExcelID.SaveAs( 'C:\Excel\Demo1.xls' );22) 放弃存盘:ExcelID.ActiveWorkBook.Saved := True;23) 关闭工作簿:ExcelID.WorkBooks.Close;24) 退出 Excel:ExcelID.Quit;25) 设置工作表密码:ExcelID.ActiveSheet.Protect "123", DrawingObjects:=True, Contents:=True, Scenarios:=True26) EXCEL的显示方式为最大化ExcelID.Application.WindowState = xlMaximized27) 工作薄显示方式为最大化ExcelID.ActiveWindow.WindowState = xlMaximized28) 设置打开默认工作薄数量ExcelID.SheetsInNewWorkbook = 329) '关闭时是否提示保存(true 保存;false 不保存)ExcelID.DisplayAlerts = False30) 设置拆分窗口,及固定行位置ExcelID.ActiveWindow.SplitRow = 1ExcelID.ActiveWindow.FreezePanes = True31) 设置打印时固定打印内容ExcelID.ActiveSheet.PageSetup.PrintTi tleRows = "$11"32) 设置打印标题ExcelID.ActiveSheet.PageSetup.PrintTi tleColumns = ""33) 设置显示方式(分页方式显示)ExcelID.ActiveWindow.View = xlPageBreakPreview34) 设置显示比例ExcelID.ActiveWindow.Zoom = 100。
用VB操作excel方法汇总
用VB操作excel方法汇总用VB操作excel方法汇总Private Sub Command3_Click()Dim i As LongDim j As LongDim objExl As Excel.Application '声明对象变量Me.MousePointer = 11 '改变鼠标样式Set objExl = New Excel.Application '初始化对象变量objExl.SheetsInNewWorkbook = 1 '将新建的工作薄数量设为1 objExl.Workbooks.Add '增加一个工作薄objExl.Sheets(objExl.Sheets.Count).Name = "book1" '修改工作薄名称objExl.Sheets.Add , objExl.Sheets("book1") '增加第二个工作薄在第一个之后objExl.Sheets(objExl.Sheets.Count).Name = "book2"objExl.Sheets.Add , objExl.Sheets("book2") '增加第三个工作薄在第二个之后objExl.Sheets(objExl.Sheets.Count).Name = "book3"objExl.Sheets("book1").Select '选中工作薄<book1>For i = 1 To 50 '循环写入数据For j = 1 To 5If i = 1 ThenobjExl.Selection.NumberFormatLocal = "@" '设置格式为文本objExl.Cells(i, j) = " E " & i & jElseobjExl.Cells(i, j) = i & jEnd IfNextNextobjExl.Rows("1:1").Select '选中第一行objExl.Selection.Font.Bold = True '设为粗体objExl.Selection.Font.Size = 24 '设置字体大小objExl.Cells.EntireColumn.AutoFit '自动调整列宽objExl.ActiveWindow.SplitRow = 1 '拆分第一行objExl.ActiveWindow.SplitColumn = 0 '拆分列objExl.ActiveWindow.FreezePanes = True '固定拆分objExl.ActiveSheet.PageSetup.PrintTitleRows = "$1:$1" '设置打印固定行objExl.ActiveSheet.PageSetup.PrintTitleColumns = "" '打印标题objExl.ActiveSheet.PageSetup.RightFooter = "打印时间: " & _ Format(Now, "yyyy年mm月dd日 hh:MM:ss")objExl.ActiveWindow.View = xlPageBreakPreview '设置显示方式objExl.ActiveWindow.Zoom = 100 '设置显示大小'给工作表加密码objExl.ActiveSheet.Protect "123", DrawingObjects:=True, _Contents:=True, Scenarios:=TrueobjExl.Application.IgnoreRemoteRequests = FalseobjExl.Visible = True '使EXCEL可见objExl.Application.WindowState = xlMaximized 'EXCEL的显示方式为最大化objExl.ActiveWindow.WindowState = xlMaximized '工作薄显示方式为最大化objExl.SheetsInNewWorkbook = 3 '将默认新工作薄数量改回3个Set objExl = Nothing '清除对象Me.MousePointer = 0 '修改鼠标Exit SubEnd Sub全面控制 Excel首先创建 Excel 对象,使用ComObj:Dim ExcelID as Excel.ApplicationSet ExcelID as new Excel.Application1) 显示当前窗口:ExcelID.Visible := True;2) 更改Excel 标题栏:ExcelID.Caption := '应用程序调用Microsoft Excel';3) 添加新工作簿:ExcelID.WorkBooks.Add;4) 打开已存在的工作簿:ExcelID.WorkBooks.Open( 'C:\Excel\Demo.xls' );5) 设置第2个工作表为活动工作表:ExcelID.WorkSheets[2].Activate;或 ExcelID.WorkSheets[ 'Sheet2' ].Activate;6) 给单元格赋值:ExcelID.Cells[1,4].Value := '第一行第四列';7) 设置指定列的宽度(单位:字符个数),以第一列为例:ExcelID.ActiveSheet.Columns[1].ColumnsWidth := 5;8) 设置指定行的高度(单位:磅)(1磅=0.035厘米),以第二行为例:ExcelID.ActiveSheet.Rows[2].RowHeight := 1/0.035; // 1厘米9) 在第8行之前插入分页符:ExcelID.WorkSheets[1].Rows[8].PageBreak := 1;10) 在第8列之前删除分页符:ExcelID.ActiveSheet.Columns[4].PageBreak := 0;11) 指定边框线宽度:ExcelID.ActiveSheet.Range[ 'B3:D4' ].Borders[2].Weight := 3;1-左 2-右 3-顶 4-底 5-斜( \ ) 6-斜( / )12) 清除第一行第四列单元格公式:ExcelID.ActiveSheet.Cells[1,4].ClearContents;13) 设置第一行字体属性:ExcelID.ActiveSheet.Rows[1] := '隶书';ExcelID.ActiveSheet.Rows[1].Font.Color := clBlue;ExcelID.ActiveSheet.Rows[1].Font.Bold := True;ExcelID.ActiveSheet.Rows[1].Font.UnderLine := True;14) 进行页面设置:a.页眉:ExcelID.ActiveSheet.PageSetup.CenterHeader := '报表演示';b.页脚:ExcelID.ActiveSheet.PageSetup.CenterFooter := '第&P页';c.页眉到顶端边距2cm:ExcelID.ActiveSheet.PageSetup.HeaderMargin := 2/0.035;d.页脚到底端边距3cm:ExcelID.ActiveSheet.PageSetup.HeaderMargin := 3/0.035;e.顶边距2cm:ExcelID.ActiveSheet.PageSetup.T opMargin := 2/0.035;f.底边距2cm:ExcelID.ActiveSheet.PageSetup.BottomMargin := 2/0.035;g.左边距2cm:ExcelID.ActiveSheet.PageSetup.LeftMargin := 2/0.035;h.右边距2cm:ExcelID.ActiveSheet.PageSetup.RightMargin := 2/0.035;i.页面水平居中:ExcelID.ActiveSheet.PageSetup.CenterHorizontally := 2/0.035;j.页面垂直居中:ExcelID.ActiveSheet.PageSetup.CenterVertically := 2/0.035;k.打印单元格网线:ExcelID.ActiveSheet.PageSetup.PrintGridLines := True;15) 拷贝操作:a.拷贝整个工作表:ed.Range.Copy;b.拷贝指定区域:ExcelID.ActiveSheet.Range[ 'A1:E2' ].Copy;c.从A1位置开始粘贴:ExcelID.ActiveSheet.Range.[ 'A1' ].PasteSpecial;d.从文件尾部开始粘贴:ExcelID.ActiveSheet.Range.PasteSpecial;16) 插入一行或一列:a. ExcelID.ActiveSheet.Rows[2].Insert;b. ExcelID.ActiveSheet.Columns[1].Insert;17) 删除一行或一列:a. ExcelID.ActiveSheet.Rows[2].Delete;b. ExcelID.ActiveSheet.Columns[1].Delete;18) 打印预览工作表:ExcelID.ActiveSheet.PrintPreview;19) 打印输出工作表:ExcelID.ActiveSheet.PrintOut;20) 工作表保存:If not ExcelID.ActiveWorkBook.Saved thenExcelID.ActiveSheet.PrintPreviewEnd if21) 工作表另存为:ExcelID.ActiveWorkbook.SaveAsFileName:="C:\Excel\Demo1.xls"22) 放弃存盘:ExcelID.ActiveWorkBook.Saved := True;23) 关闭工作簿:ExcelID.WorkBooks.Close;24) 退出 Excel:ExcelID.Quit;25) 设置工作表密码:ExcelID.ActiveSheet.Protect "123", DrawingObjects:=True, Contents:=True, Scenarios:=True26) EXCEL的显示方式为最大化ExcelID.Application.WindowState = xlMaximized27) 工作薄显示方式为最大化ExcelID.ActiveWindow.WindowState = xlMaximized28) 设置打开默认工作薄数量ExcelID.SheetsInNewWorkbook = 329) '关闭时是否提示保存(true 保存;false 不保存) ExcelID.DisplayAlerts = False30) 设置拆分窗口,及固定行位置ExcelID.ActiveWindow.SplitRow = 1ExcelID.ActiveWindow.FreezePanes = True31) 设置打印时固定打印内容ExcelID.ActiveSheet.PageSetup.PrintTitleRows = "$1:$1"32) 设置打印标题ExcelID.ActiveSheet.PageSetup.PrintTitleColumns = ""33) 设置显示方式(分页方式显示)ExcelID.ActiveWindow.View = xlPageBreakPreview34) 设置显示比例ExcelID.ActiveWindow.Zoom = 100Excel 语句集300定制模块行为(1) Option Explicit '强制对模块内所有变量进行声明Option Private Module '标记模块为私有,仅对同一工程中其它模块有用,在宏对话框中不显示Option Compare Text '字符串不区分大小写Option Base 1 '指定数组的第一个下标为1(2) On Error Resume Next '忽略错误继续执行VBA代码,避免出现错误消息(3) On Error GoTo ErrorHandler '当错误发生时跳转到过程中的某个位置(4) On Error GoT o 0 '恢复正常的错误提示(5) Application.DisplayAlerts=False '在程序执行过程中使出现的警告框不显示(6) Application.ScreenUpdating=False '关闭屏幕刷新Application.ScreenUpdating=True '打开屏幕刷新(7) Application.Enable.CancelKey=xlDisabled '禁用Ctrl+Break中止宏运行的功能工作簿(8) Workbooks.Add() '创建一个新的工作簿(9) Workbooks(“book1.xls”).Activate '激活名为book1的工作簿(10) ThisWorkbook.Save '保存工作簿(11) ThisWorkbook.close '关闭当前工作簿(12) ActiveWorkbook.Sheets.Count '获取活动工作薄中工作表数(13) '返回活动工作薄的名称(14) ‘返回当前工作簿名称ThisWorkbook.FullName ‘返回当前工作簿路径和名称(15) ActiveWindow.EnableResize=False ‘禁止调整活动工作簿的大小(16) Application.Window.Arrange xlArrangeStyleTiled ‘将工作簿以平铺方式排列(17) ActiveWorkbook.WindowState=xlMaximized ‘将当前工作簿最大化工作表(18) edRange.Rows.Count ‘当前工作表中已使用的行数(19) Rows.Count ‘获取工作表的行数(注:考虑向前兼容性)(20) Sheets(Sheet1).Name= “Sum” '将Sheet1命名为Sum(21) ThisWorkbook.Sheets.Add Before:=Worksheets(1) '添加一个新工作表在第一工作表前(22) ActiveSheet.Move After:=ActiveWorkbook. _Sheets(ActiveWorkbook.Sheets.Count) '将当前工作表移至工作表的最后(23) Worksheets(Array(“sheet1”,”sheet2”)).Select '同时选择工作表1和工作表2(24) Sheets(“sheet1”).Delete或Sheets(1).Delete '删除工作表1(25) ActiveWorkbook.Sheets(i).Name '获取工作表i的名称(26) ActiveWindow.DisplayGridlines=Not ActiveWindow.DisplayGridlines '切换工作表中的网格线显示,这种方法也可以用在其它方面进行相互切换,即相当于开关按钮(27) ActiveWindow.DisplayHeadings=Not ActiveWindow.DisplayHeadings ‘切换工作表中的行列边框显示(28) edRange.FormatConditions.Delete ‘删除当前工作表中所有的条件格式(29) Cells.Hyperlinks.Delete ‘取消当前工作表所有超链接(30) ActiveSheet.PageSetup.Orientation=xlLandscape或ActiveSheet.PageSetup.Orientation=2 '将页面设置更改为横向(31)ActiveSheet.PageSetup.RightFooter=ActiveWorkbook.FullName ‘在页面设置的表尾中输入文件路径ActiveSheet.PageSetup.LeftFooter=erName‘将用户名放置在活动工作表的页脚单元格/单元格区域(32) ActiveCell.CurrentRegion.Select或Range(ActiveCell.End(xlUp),ActiveCell.End(xlDown)).Select '选择当前活动单元格所包含的范围,上下左右无空行(33) Cells.Select ‘选定当前工作表的所有单元格(34) Range(“A1”).ClearContents '清除活动工作表上单元格A1中的内容Selection.ClearContents '清除选定区域内容Range(“A1:D4”).Clear '彻底清除A1至D4单元格区域的内容,包括格式(35) Cells.Clear '清除工作表中所有单元格的内容(36) ActiveCell.Offset(1,0).Select '活动单元格下移一行,同理,可下移一列(37) Range(“A1”).Offset(ColumnOffset:=1)或Range(“A1”).Offset(,1) ‘偏移一列Range(“A1”).Offset(Rowoffset:=-1)或Range(“A1”).Offset(-1) ‘向上偏移一行(38) Range(“A1”).Copy Range(“B1”) '复制单元格A1,粘贴到单元格B1中Range(“A1:D8”).Copy Range(“F1”) '将单元格区域复制到单元格F1开始的区域中Range(“A1:D8”).Cut Range(“F1”) '剪切单元格区域A1至D8,复制到单元格F1开始的区域中Range(“A1”).CurrentRegion.Copy Sheets(“Sheet2”).Range(“A1”) '复制包含A1的单元格区域到工作表2中以A1起始的单元格区域中注:CurrentRegion属性等价于定位命令,由一个矩形单元格块组成,周围是一个或多个空行或列(39) ActiveWindow.RangeSelection.Value=XX '将值XX输入到所选单元格区域中(40) ActiveWindow.RangeSelection.Count '活动窗口中选择的单元格数(41) Selection.Count '当前选中区域的单元格数(42)GetAddress=Replace(Hyperlinkcell.Hyperlinks(1).Address,mailto: ,””) ‘返回单元格中超级链接的地址并赋值(43) TextColor=Range(“A1”).Font.ColorIndex ‘检查单元格A1的文本颜色并返回颜色索引Range(“A1”).Interior.ColorIndex ‘获取单元格A1背景色(44) cells.count ‘返回当前工作表的单元格数(45) Selection.Range(“E4”).Select ‘激活当前活动单元格下方3行,向右4列的单元格(46) Cells.Item(5,”C”) ‘引单元格C5Cells.Item(5,3) ‘引单元格C5(47) Range(“A1”).Offset(RowOffset:=4,ColumnOffset:=5)或 Range(“A1”).Offset(4,5) ‘指定单元格F5(48) Range(“B3”).Resize(RowSize:=11,ColumnSize:=3)Rnage(“B3”).Resize(11,3) ‘创建B3:D13区域(49) Range(“Data”).Resize(,2) ‘将Data区域扩充2列(50) Union(Range(“Data1”),Range(“Data2”)) ‘将Data1和Data2区域连接(51) Intersect(Range(“Data1”),Range(“Data2”)) ‘返回Data1和Data2区域的交叉区域(52) Range(“Data”).Count ‘单元格区域Data中的单元格数Range(“Data”). Columns.Count ‘单元格区域Data中的列数Range(“Data”). Rows.Count ‘单元格区域Data中的行数(53) Selection.Columns.Count ‘当前选中的单元格区域中的列数Selection.Rows.Count ‘当前选中的单元格区域中的行数(54) Selection.Areas.Count ‘选中的单元格区域所包含的区域数(55) edRange.Row ‘获取单元格区域中使用的第一行的行号(56) Rng.Column ‘获取单元格区域Rng左上角单元格所在列编号(57)ActiveSheet.Cells.SpecialCells(xlCellTypeAllFormatConditions)‘在活动工作表中返回所有符合条件格式设置的区域(58) Range(“A1”).AutoFilter Field:=3,VisibleDropDown:=False ‘关闭由于执行自动筛选命令产生的第3个字段的下拉列表名称(59) Range(“A1:C3”).Name=“computer”‘命名A1:C3区域为computer或Range(“D1:E6”).Name=“Sheet1!book”‘命名局部变量,即Sheet1上区域D1:E6为book或Names(“computer”).Name=“robot”‘将区域computer重命名为robot(60) Names(“book”).Delete ‘删除名称(61) Names.Add Name:=“ContentList”,_RefersT o:=“=OFFSET(Sheet1!A2,0,0,COUNTA(Sheet2!$A:$A))”‘动态命名列(62) Names.Add Name:=“Company”,RefersTo:=“CompanyCar”‘命名字符串CompanyCar(63) Names.Add Name:=“T otal”,RefersTo:=123456 ‘将数字123456命名为T otal。
VBA与Excel间的数据交互技巧
VBA与Excel间的数据交互技巧在Excel中,VBA(Visual Basic for Applications)是一种强大的编程语言,可以帮助用户更好地处理和操作数据。
VBA与Excel之间的数据交互技巧可以提高工作效率,简化数据处理过程,并实现自动化操作。
本文将介绍一些常用的VBA与Excel间的数据交互技巧,以帮助读者更好地利用VBA提高工作效率。
首先,我们将讨论如何将Excel中的数据导入VBA中进行处理。
在编写VBA代码时,我们可以使用Excel对象模型来访问和处理Excel工作表中的数据。
使用"Workbooks.Open"方法,我们可以打开一个Excel文件,并将其赋值给一个变量。
通过这种方式,我们可以直接从Excel文件中读取数据,并在VBA中进行处理。
例如,我们可以使用"Range"属性来选择特定的单元格范围,并使用"Cells"属性来访问特定的单元格,以读取或修改其值。
在VBA中操作Excel数据的另一个常见需求是将VBA处理后的数据导出到Excel中。
使用"Workbooks.Add"方法,我们可以创建一个新的Excel工作簿,并将其赋值给一个变量。
然后,我们可以使用"Range"属性和"Cells"属性将数据写入到Excel工作表中的特定单元格。
例如,我们可以使用"Cells(i, j).Value"来设置第i行、第j列的单元格的值。
此外,我们还可以使用"Range"属性的"Copy"方法将某个范围的数据复制到粘贴板,然后使用"ActiveSheet.Paste"方法将其粘贴到Excel工作表中的特定位置。
除了读取和写入单元格数据,VBA还支持对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.Worksheet3、在程序中操作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进行操作。
通过VB操作Excel的应用
通过VB操作Excel的应用姜新【摘要】文章介绍了通过VB随机生成的一组学生成绩数据保存到一个Excel工作表中的实例,对Excel进行相应的操作,然后实现调用Excel中的VBA指令将刚生成的文件打开并执行各种排版操作。
%This paper introduces the save to a Excel worksheet examples through a group of student achievement data VB generated randomly, the operation of the corresponding to the Excel, and then the realization of calls in Excel VBA command will just generated ifle open and perform various typesetting operation.【期刊名称】《无线互联科技》【年(卷),期】2015(000)004【总页数】3页(P52-54)【关键词】Visul Basic;Excel;排版【作者】姜新【作者单位】营口职业技术学院,辽宁营口 115000【正文语种】中文1 引言VB是可视化、事件驱动、面向对象的结构化程序设计语言,已经成为许多学好编程的专业程序员做为Windows应用程序的开发工具,具有强大的数据处理功能,但要想用VB输出比较复杂的表格是很困难的,比如对表格的排版操作,Excel的数据处理功能相对较弱,但Excel对表格的排版等操作是很容易来实现的,Excel是非常强大的电子表格处理软件,在EXCEL中处理数据是很多人都喜欢的,在VB 中引用的话,得用到Excel对象库,这样在Vb的代码窗口中可以应用[1]。
通过应用程序VB来操控Excel,其实就是在VB中将Excel作为一个外部对象来引用,就是通过Excel提供的对象及其对象的属性、方法和事件,然后在VB的代码窗口中进行调用的过程。
VB处理EXCEL数据方法
在VB中要想调用Excel,需要打开VB编程环境“工程”菜单中的“引用”项目,并选取项目中的“Microsoft Excel 11.0 object library”项。
由于你的Excel 版本不同,所以这个选项的版本号也是不同的。
因为EXCEL是以层次结构组织对象的,其对象模型中含有许多不同的对象元素。
第一层:Application对象,即Excel本身;第二层:workbooks对象集,指Excel的工作簿文件;第三层:worksheets对象集,表示的是Excel的一个工作表;第四层:Cells和Range对象,指向Excel工作表中的单元格。
新建立一个VB的工程,先放一个button,名称为Excel_Out。
先定义好各层:Dim xlapp As Excel.Application 'Excel对象Dim xlbook As Excel.Workbook '工作簿Dim xlsheet As Excel.Worksheet '工作表我们打算做的是:打开/新建一个excel,在其中对某工作表的一些单元格修改其值,然后另存为test.xls文件。
Private Sub Excel_Out_Click()Dim i, j As IntegerSet xlapp = CreateObject("Excel.Application") '创建EXCEL对象'Set xlbook = xlapp.Workbooks.Open(App.Path & "\test.xls") '打开已经存在的test.xls工件簿文件Set xlbook = xlapp.Workbooks.Add '新建EXCEL工件簿文件'xlbook.RunAutoMacros (xlAutoOpen) '运行EXCEL启动宏'xlbook.RunAutoMacros (xlAutoClose) '运行EXCEL关闭宏xlapp.Visible = True '设置EXCEL对象可见(或不可见)Set xlsheet = xlbook.Worksheets(1) '设置活动工作表''''~~~当前工作簿的第一页,这里也可以换成“表名”'下面就是简单的在一些单元格内写入数字For i = 7 To 15For j = 1 To 10xlsheet.Cells(i, j) = j '当前工作簿第一页的第I行第J列Next jNext iWith xlsheet '设置边框为是实线.Range(.Cells(7, 1), .Cells(28, 29)).Borders.LineStyle =xlContinuousEnd With'引用当前工作簿的第二页Set xlsheet = xlapp.Application.Worksheets(2)xlsheet.Cells(7, 2) = 2008 '在第二页的第7行第2列写入2008 xlsheet.SaveAs App.Path & "\test.xls" '按指定文件名存盘'Set xlbook = xlapp.Application.Workbooks.Add '新建一空白工作簿xlapp.Quit '结束EXCEL对象'xlapp.Workbooks.CloseSet xlapp = Nothing '释放xlApp对象End Sub这样,我们就可以简单的对excel文件进行操作了。
VB编程:使用MSHFlexGrid控件与Excel互传数据
VB编程:使用MSHFlexGrid控件与Excel互传数据使用MSHFlexGrid控件获取并更新Excel中的数据要点:1、工程-引用,勾选Microsoft Excel 11.0 Object Libraly。
2、工程-部件,勾选Microsoft Hierarchical FlexGridControl 6.0。
3、在窗体添加一个MSHFlexGrid控件。
4、将需要打开更新的电子表格设置为“共享”(非常重要),方法:工具--共享工作簿。
代码:Private Sub Form_Load()Dim xlExcel As Excel.ApplicationDim xlBook As Excel.WorkbookDim xlSheet As Excel.WorksheetDim AppExcel As ObjectSet xlExcel = CreateObject("Excel.Application")xlExcel.Workbooks.Open "C:\Program Files\Microsoft Visual Studio\mywork\book1.xls"Set xlBook = xlExcel.Workbooks("book1.xls")Set xlSheet = xlBook.Worksheets(2)'选择第2个工作表Dim i As LongWith xlSheetx = 2y = 1While .Cells(2, y).Value <> ""y = y + 1WendWhile .Cells(x, 1).Value <> ""x = x + 1Wend'Debug.Print .RowsMSHFlexGrid1.Rows = x - 1MSHFlexGrid1.Cols = y - 1 MSHFlexGrid1.TextMatrix(0, 0) = .Cells(2, 1).ValueFor j = 2 To MSHFlexGrid1.ColsDim k As Integerk = jIf k Mod 2 = 1 Then k = k - 1MSHFlexGrid1.TextMatrix(0, j - 1) = .Cells(1, k) & .Cells(2, j) NextFor i = 3 To MSHFlexGrid1.RowsFor j = 1 To MSHFlexGrid1.Cols MSHFlexGrid1.TextMatrix(i - 2, j - 1) = .Cells(i, j).ValueNextNextEnd WithWith MSHFlexGrid1.Col = 1.Row = 1' .CellBackColor = vbBlueEnd With xlBook.Close (False) '关闭EXCEL工作簿Set xlSheet = NothingSet xlBook = NothingxlExcel.Quit '关闭EXCELSet xlExcel = Nothing '释放EXCEL对象End SubPrivate Sub Command4_Click() Dim xlExcel AsExcel.ApplicationDim xlBook As Excel.WorkbookDim xlSheet As Excel.WorksheetDim AppExcel As Object'MSFlexGrid1.Redraw = FalseSet xlExcel = CreateObject("Excel.Application")Set xlBook = xlExcel.Workbooks.Open("C:\Program Files\Microsoft Visual Studio\mywork\book1.xls", , ReadWrite) 'Set xlBook = xlExcel.Workbooks("zkb.xls")Set xlSheet = xlBook.Worksheets(2)' xlExcel.Visible = True '设置工作簿为可见With xlSheetFor i = 3 To MSHFlexGrid1.RowsFor j = 1 To MSHFlexGrid1.Cols .Cells(i, j) = MSHFlexGrid1.TextMatrix(i - 2, j - 1)NextNext End With'MSFlexGrid1.Redraw = TruexlBook.SavexlExcel.DisplayAlerts = FalsexlBook.Close (False) '关闭EXCEL工作簿Set xlSheet = NothingSet xlBook = NothingxlExcel.Quit '关闭EXCELSet xlExcel = Nothing '释放EXCEL对象End SubPrivate Sub Form_Load()Dim xlExcel As Excel.ApplicationDim xlBook As Excel.WorkbookDim xlSheet As Excel.WorksheetDim AppExcel As ObjectSet xlExcel = CreateObject("Excel.Application")xlExcel.Workbooks.Open "C:\Program Files\Microsoft Visual Studio\mywork\book1.xls"Set xlBook = xlExcel.Workbooks("book1.xls")Set xlSheet = xlBook.Worksheets(2)Dim i As LongWith xlSheetx = 2y = 1While .Cells(2, y).Value <> ""y = y + 1WendWhile .Cells(x, 1).Value <> ""x = x + 1Wend'Debug.Print .RowsMSHFlexGrid1.Rows = x - 1MSHFlexGrid1.Cols = y - 1 MSHFlexGrid1.TextMatrix(0, 0) = .Cells(2, 1).ValueFor j = 2 To MSHFlexGrid1.ColsDim k As Integerk = jIf k Mod 2 = 1 Then k = k - 1MSHFlexGrid1.TextMatrix(0, j - 1) = .Cells(1, k) & .Cells(2, j) NextFor i = 3 To MSHFlexGrid1.RowsFor j = 1 To MSHFlexGrid1.Cols MSHFlexGrid1.TextMatrix(i - 2, j - 1) = .Cells(i, j).ValueNextNextEnd WithWith MSHFlexGrid1.Col = 1.Row = 1' .CellBackColor = vbBlueEnd With xlBook.Close (False) '关闭EXCEL工作簿Set xlSheet = NothingSet xlBook = NothingxlExcel.Quit '关闭EXCELSet xlExcel = Nothing '释放EXCEL对象End SubPrivate Sub MSHFlexGrid1_Click()With MSHFlexGrid1.CellBackColor = vbCyanText3 = .TextMatrix(.Row, .Col)End WithText3.SetFocusEnd SubPrivate Sub MSHFlexGrid1_DblClick()With MSHFlexGrid1If .CellBackColor = vbCyan Then .CellBackColor = &HFFFFFF End WithEnd Sub。
vb程序调用excel数据
Visual Basic调用Excel之技巧吴声松(湖北省水利水电勘测设计院地质大队湖北430070)Visual Basic(以下简称VB)是一套可视化、面向对象、事件驱动方式的结构化程序设计语言,已经成为许多程序设计者甚至专业程序员用来开发WINDOWS应用程序的首选开发工具。
但用过VB的程序设计人员都知道,要想用VB输出复杂的表格来,是十分困难的。
能不能用VB 调用EXCEL呢?Active技术标准为我们解决了这个问题。
最近笔者为单位开发“土工试验数据整理”的某个模块时,涉及到复杂数据表格的输出问题,经过笔者的摸索,用VB调用EXCEL,取得了很好的效果。
本文从编程实践的角度对使用VB控制EXCEL的技术作简要说明。
1 EXCEL的对象模型如果一个应用程序支持自动化技术,那么其它的应用就可以通过其暴露的对象,对它进行控制,控制程序称为客户机,而被控制的一方就称为服务器,被控制的对象就是Active对象。
VB正是通过EXCEL显露的各级对象来控制EXCEL工作的。
每个对象都有各自的方法和属性,通过方法可以实现对对象的控制,而属性则可以改变对象的各种状态。
理解EXCEL的对象模型是对其编程的基础。
EXCEL是以层次结构组织对象的,其对象模型中含有许多不同的对象元素,这些对象元素就是VB可以操纵的。
在EXCEL对象的层次结构中,最顶层是Application 对象,是Excel本身。
从该对象开始往下依次是:.workbooks对象集,是Application对象的下层,其指的是Excel的工作簿文件。
.worksheets对象集,是Workbooks对象集的下层,它表示的是Excel的一个工作表。
.Cells和Range对象,它们是worksheets对象的下层,它则指向Excel工作表中的一个或多个单元格。
以上介绍的四个对象是Excel中最重要也是用得最多的对象,而且从上面的介绍中也不难看出,要控制Excel中的某个具体对象,如某个工作簿中某一表格中的单元格,就必须从Excel层次结构对象的最上层即Application对象开始遍历。
VBA与EXCEL进行交互
VBA与EXCEL进行交互在使用Excel的过程中,应用程序经常会显示不同样式的对话框来实现多种多样的用户交互功能。
在使用VBA编写程序时,为了提高代码的灵活性和程序的友好度,经常需要实现用户与Excel的交互功能。
本章将介绍如何使用InputBox和MsgBox实现输入和输出信息。
45.1 使用MsgBox输出信息在代码中,MsgBox函数通常应用于如下几种情况:◆ 输出代码最终运行结果。
◆ 显示一个对话框用于提醒用户。
◆ 在对话框中显示提示信息,等待用户单击按钮,根据用户的选择执行相应的代码。
◆ 在代码运行过程中显示某个变量的值用于调试代码。
MsgBox函数的语法格式如下:MsgBox(prompt[, buttons] [, title] [, helpfile, context])表格45-1中列出了MsgBox函数的参数及其含义。
表格45-1 MsgBox函数参数列表45.1.1 显示多行文本信息prompt参数用于设置对话框的提示文本信息,最大长度为1024个字符,显然这么多的字符无法显示在同一行。
如果代码中没有使用强制换行,系统将按照每行102字符进行自动换行处理,多数情况下这并不符合用户的使用习惯。
因此如果prompt参数的内容超过一行,则应该在每一行之间用回车符(Chr(13))、换行符(Chr(10))或是回车与换行符的组合(Chr (13)& Chr(10))将各行分隔开来。
代码中也可以使用使用vbCrLf或者vbNewLine常量进行强制换行。
步骤1 在Excel中新建一个空白工作簿文件,按<Alt+F11>组合键切换到VBE窗口。
步骤2 在工程资源浏览器中插入“模块”,并修改其名称为“MsgBoxDemo1”。
步骤3 在工程资源浏览器中双击模块MsgBoxDemo1,在代码窗口中写入如下代码。
#001 Sub MultiLineDemo()#002 Dim MsgStr As String#003 MsgStr = "Excel Home是微软技术社区联盟成员" & Chr(13) & Chr(10) #004 MsgStr = MsgStr & "欢迎加入Excel Home论坛!" & vbCrLf#005 MsgStr = MsgStr & "Let's do it better!"#006 MsgBox MsgStr, , "欢迎"#007 End Sub步骤4 返回Excel界面,运行MultiLineDemo过程,将显示如图45-1所示的对话框。
利用剪贴板实现Excel与VB表格之间的数据传递
利用剪贴板实现Excel与VB表格之间的数据传递
聂玉峰
【期刊名称】《铁道勘测与设计》
【年(卷),期】2003(000)006
【摘要】在利用VB进行程序开发时,我们往往需要对大量的数据进行操作,特别是在引用其他程序计算的大量结果作为原始数据时,更加需要一种简便的方法实现这种大量数据的传递,作者在编制铁路桥墩检算程序时,通过对这种数据传递进行研究,编制了一个比较简洁的剪贴板粘贴函数,实现了从电子表格中复制桥墩垫石顶荷载数据到VB表格之间的数据传递,供读者参考.
【总页数】3页(P64-66)
【作者】聂玉峰
【作者单位】无
【正文语种】中文
【中图分类】TP3
【相关文献】
1.如何利用VB实现Excel数据和Access数据之间的转换 [J], 邵冬华
2.利用VBA实现Excel电子表格(工资报表)自动分页统计 [J], 王志华;蒲前梅;张玉波;雷庆华;
3.利用简单的VBA实现Excel表格计算 [J], 姜亚东
4.用VBA实现Excel电子表格到AutoCAD表格的转换 [J], 朱玉
5.基于VBA实现Excel和Word之间的数据传递 [J], 张文晓
因版权原因,仅展示原文概要,查看原文内容请购买。
excel vb conversion用法
excel vb conversion用法Excel VBA (Visual Basic for Applications) 是一种编程语言,用于通过自动化Excel来进行数据处理、分析和操作。
其中,Excel VB Conversion 是Excel VBA 中一种常见的方法之一。
在本文中,我将详细介绍Excel VB Conversion的使用方法。
第一步:了解Excel VBA和VB Conversion的基本知识在开始学习和应用Excel VB Conversion之前,我们需要了解一些基本的概念。
Excel VBA是一种将Visual Basic编程语言集成到Excel中的方式。
它允许用户通过编写宏来自动化执行各种任务,如数据处理、报表生成等。
而VB Conversion 是指将其他编程语言(如、C#等)的代码转换为Excel VBA代码的过程。
第二步:选择需要转换的代码在使用Excel VB Conversion之前,我们需要选择要转换的代码。
这可以是任何其他编程语言中的代码,例如、C#或Python。
选择适当的代码非常重要,因为某些代码可能无法进行有效转换,或者可能需要进行适当的修改以保证正确性和性能。
第三步:了解Excel VBA的语法和结构在将其他编程语言的代码转换为Excel VBA之前,我们需要了解Excel VBA的语法和结构。
这包括变量和数据类型、条件语句、循环结构、函数和子过程等。
只有深入了解这些基础知识,我们才能更好地进行代码转换和优化。
第四步:逐行转换代码一旦我们了解了Excel VBA的语法和结构,我们就可以逐行转换代码了。
这意味着将一行一行的其他编程语言代码翻译成Excel VBA代码。
在转换过程中,我们需要详细了解其他编程语言中的功能和Excel VBA中的等效功能,并进行相应的调整和修改。
第五步:进行代码测试和调试转换完成后,我们需要对转换后的代码进行测试和调试。
excel vb conversion用法
excel vb conversion用法(实用版)目录1.Excel 与 VB 的转换概述2.Excel 图表复制到 VB 的方法3.VBA 与 VB 中图片控件的用法4.将 Word 文档转换为 Excel 的方法5.总结正文一、Excel 与 VB 的转换概述Excel 和 VB(Visual Basic)是两种不同的软件开发工具,它们在功能和用途上有很大的区别。
Excel 是一款电子表格软件,主要用于数据处理和分析,而 VB 则是一款编程语言,可以用来开发 Windows 应用程序。
有时候,我们需要将 Excel 中的数据或图表复制到 VB 程序中,那么如何实现这种转换呢?二、Excel 图表复制到 VB 的方法在 VB 中,我们可以使用 PictureBox 或 Image 控件来显示 Excel 图表。
首先,需要在 Excel 中将图表复制到剪贴板,然后在 VB 中将剪贴板中的图表粘贴到 PictureBox 或 Image 控件的 Picture 属性中。
需要注意的是,无论是 PictureBox 还是 Image 控件,都没有 Paste 方法,只能通过设置 Picture 属性来实现图表的显示。
三、VBA 与 VB 中图片控件的用法在 VBA 中,我们可以使用 Image 控件来显示图片。
与 VB 类似,需要将图片复制到剪贴板,然后在 VBA 代码中使用 Image 控件的Picture 属性来粘贴图片。
在 VB 中,我们可以使用 PictureBox 控件来显示图片,同样需要将图片复制到剪贴板,然后在 VB 代码中使用PictureBox 控件的 Picture 属性来粘贴图片。
四、将 Word 文档转换为 Excel 的方法有时候,我们需要将 Word 文档中的数据转换为 Excel 表格。
有两种方法可以实现这一目的:1.使用 Microsoft Access。
将 Word 文档中的数据复制到 Access 表格中,然后使用 Access 提供的数据导入功能将数据导入到 Excel 表格中。
VBA与Excel的数据交互教程
VBA与Excel的数据交互教程在Excel的日常使用中,我们经常需要对大量的数据进行处理和分析。
VBA(Visual Basic for Applications)是一种用于自动化任务的编程语言,它能够对Excel进行自定义的扩展和功能增强。
通过使用VBA,我们可以轻松地实现Excel与其他应用的数据交互,提高数据处理的效率和准确性。
首先,我们需要了解VBA与Excel之间的数据交互方式。
Excel提供了VBA的开发环境,我们可以通过VBA编辑器来编写和运行VBA代码。
在VBA中,我们可以使用各种对象来操作Excel的数据,例如Workbook、Worksheet和Range等。
在Excel中,最常见的数据交互方式是通过将数据从Excel复制到其他应用程序或从其他应用程序粘贴到Excel中。
在VBA中,我们可以使用Copy和Paste方法来实现数据的复制和粘贴。
例如,我们可以使用Range对象的Copy方法将选定的单元格数据复制到剪贴板,然后使用Paste方法将剪贴板中的数据粘贴到另一个单元格中。
下面是一个简单的示例代码,演示了如何使用VBA实现Excel与其他应用程序(例如Word)之间的数据交互:```Sub CopyDataToWord()Dim wordApp As ObjectDim wordDoc As Object' 创建Word应用程序对象Set wordApp = CreateObject("Word.Application") ' 打开Word文档Set wordDoc = wordApp.Documents.Add' 复制选定的单元格数据Range("A1:B2").Copy' 将数据粘贴到Word文档中wordApp.Selection.Paste' 关闭Word应用程序wordApp.Quit' 释放内存Set wordDoc = NothingSet wordApp = NothingEnd Sub```上述代码首先创建了一个Word应用程序对象,然后打开了一个新的Word文档。
使用VB将变量记录中的数据写入EXCEL
使用VBS读取变量归档数据到EXCEL1、创建变量。
过程归档变量、查询时间变量(一个起始时间、一个结束时间、时间间隔)过程变量为模拟量,其实时间和结束时间是文本变量8位字符集(时间的格式是XXXX-XX-XX XX:XX:XX),时间间隔位10进制数(单位秒)2、创建归档。
变量记录中选择好要记录的过程变量,设置好归档的时间等。
3、创建EXCEL表格模版,XXX.XLSX.4、界面上3个输入输入输出域(一个起始时间,一个结束时间,一个时间间隔),一个查询并生成EXCEL表格的按钮5、脚本主要分2块。
1是时间的转换,WINCC归档使用的时间是UTC(国际协调时间),所以需要进行时间的转换。
2是查询并生成EXCEL表格的脚本。
6、过程值归档的记录结构如下:脚本见文本文档'查询按钮中的代码(按钮)Sub OnLButtonUp(ByVal Item, ByVal Flags, ByVal x, ByVal y)Dim sPro,sDsn,sSer,sCon,conn,sSql,oRs,oComDim tagDSNNameDim m,iDim LocalBeginTime, LocalEndTime,UTCBeginTime, UTCEndTime,sValDim objExcelApp,objExcelBook,objExcelSheet,sheetnameitem.Enabled = FalseOn Error Resume Nextsheetname="Sheet1"Set objExcelApp = CreateObject("Excel.Application")objExcelApp.Visible = FalseobjExcelApp.Workbooks.Open "D:\WinCCWriteExcel\abc.xlsx"objExcelApp.Worksheets(sheetname).ActivateSet tagDSNName = HMIRuntime.Tags("@DatasourceNameRT")tagDSNName.ReadSet LocalBeginTime = HMIRuntime.Tags("strBeginTime")LocalBeginTime.ReadSet LocalEndTime = HMIRuntime.Tags("strEndTime")LocalEndTime.ReadUTCBeginTime = DateAdd("h" ,-8,LocalBeginTime.Value)UTCEndTime= DateAdd("h" ,-8,LocalEndTime.Value)UTCBeginTime = Year(UTCBeginTime) & "-" & Month(UTCBeginTime) & "-" & Day(UTCBeginTime) & " " & Hour(UTCBeginTime) & ":" & Minute(UTCBeginTime) & ":" & Second(UTCBeginTime)UTCEndTime = Year(UTCEndTime) & "-" & Month(UTCEndTime) & "-" & Day(UTCEndTime) & " " & Hour(UTCEndTime) & ":" & Minute(UTCEndTime) & ":" & Second(UTCEndTime)HMIRuntime.Trace "UTC Begin Time: " & UTCBeginTime & vbCrLfHMIRuntime.Trace "UTC end Time: " & UTCEndTime & vbCrLfSet sVal = HMIRuntime.Tags("sVal")sVal.ReadsPro = "Provider=WinCCOLEDBProvider.1;"sDsn = "Catalog=" &tagDSNName.Value& ";"sSer = "Data Source=.\WinCC"sCon = sPro + sDsn + sSerSet conn = CreateObject("ADODB.Connection")conn.ConnectionString = sConconn.CursorLocation = 3conn.OpensSql = "Tag:R,('PVArchive\NewTag'),'" & UTCBeginTime & "','" & UTCEndTime & "',"sSql=sSql+"'order by Timestamp ASC','TimeStep=" & sVal.Value & ",1'"MsgBox sSqlSet oRs = CreateObject("ADODB.Recordset")Set oCom = CreateObject("mand")mandType = 1Set oCom.ActiveConnection = connmandText = sSqlSet oRs = oCom.Executem = oRs.RecordCountIf (m > 0) ThenobjExcelApp.Worksheets(sheetname).cells(2,1).value=oRs.Fields(0).NameobjExcelApp.Worksheets(sheetname).cells(2,2).value=oRs.Fields(1).NameobjExcelApp.Worksheets(sheetname).cells(2,3).value=oRs.Fields(2).NameobjExcelApp.Worksheets(sheetname).cells(2,4).value=oRs.Fields(3).NameobjExcelApp.Worksheets(sheetname).cells(2,5).value=oRs.Fields(4).NameoRs.MoveFirsti=3Do While Not oRs.EOFobjExcelApp.Worksheets(sheetname).cells(i,1).value= oRs.Fields(0).ValueobjExcelApp.Worksheets(sheetname).cells(i,2).value=GetLocalDate(oRs.Fields(1).Value)objExcelApp.Worksheets(sheetname).cells(i,3).value= oRs.Fields(2).ValueobjExcelApp.Worksheets(sheetname).cells(i,4).value= oRs.Fields(3).ValueobjExcelApp.Worksheets(sheetname).cells(i,5).value= oRs.Fields(4).ValueoRs.MoveNexti=i+1LoopoRs.CloseElseMsgBox "没有所需数据……"item.Enabled = TrueSet oRs = Nothingconn.CloseSet conn = NothingobjExcelApp.Workbooks.CloseobjExcelApp.QuitSet objExcelApp= NothingExit SubEnd IfSet oRs = Nothingconn.CloseSet conn = NothingDim patch,filenamefilename=CStr(Year(Now))&""&CStr(Month(Now))&""&CStr(Day(Now))&""&CStr(Hour(Now) )&""&CStr(Minute(Now))&""&CStr(Second(Now))patch= "d:\"&filename&"demo.xlsx"objExcelApp.ActiveWorkbook.SaveAs patchobjExcelApp.Workbooks.CloseobjExcelApp.QuitSet objExcelApp= NothingMsgBox "成功生成数据文件!"item.Enabled = TrueEnd Sub时间转换脚本(全局)Function GetLocalDate(vtDate)Dim DoYDim dsoDim dwiDim strComputer, objWMIService, colItems, objItemDim TimeZoneDim vtDateLocalDatestrComputer = "."Set objWMIService = GetObject("winmgmts:" & "{impersonationLevel=impersonate}!\\" & strComputer & "\root\cimv2")Set colItems = objWMIService.ExecQuery("Select * from Win32_TimeZone")For Each objItem In colItemsTimeZone = objItem.Bias / 60NextIf IsDate(vtDate) <> True ThenIS_GetLocalDate = FalseExit FunctionEnd IfDoY = DatePart("y", vtDate)dso = DatePart("y", "31.03") - DatePart("w", "31.03") + 1dwi = DatePart("y", "31.10") - DatePart("w", "31.10") + 1If DoY >= dso And DoY < dwi ThenTimeZone = TimeZone + 1End IfvtDateLocalDate = DateAdd("h", 1 * TimeZone, vtDate) GetLocalDate = vtDateLocalDateEnd Function实验成功后将在指定的位置创建EXCEL表格,表格内容如下:。
VBA与Excel工作表的交互技巧
VBA与Excel工作表的交互技巧在Excel的应用中,VBA(Visual Basic for Applications)是一种强大的编程语言,它可以与Excel工作表交互,为用户提供更高效、更灵活的数据处理和操作功能。
本文将介绍几种常用的VBA与Excel工作表的交互技巧,帮助读者更好地利用VBA提高工作效率。
1. 自动化数据输入VBA可以通过自动化数据输入的方式,大大提高数据录入的效率。
可以使用VBA中的InputBox函数获取用户输入的数据,并将其自动填入指定的单元格。
例如,可以编写一个宏来弹出一个对话框,要求用户输入产品名称和销售数量,然后将数据自动填入指定的单元格。
这种方法在大量重复输入数据时非常实用,可以大大减轻用户的工作负担。
2. 条件格式化通过使用VBA,可以实现更复杂的条件格式化。
条件格式化可以根据单元格的数值或者其他条件来改变单元格的格式,使得数据更易读和理解。
VBA中的If语句可以用于判断某些条件是否满足,然后根据判断结果设置相应的条件格式。
例如,可以编写一个宏来判断某个单元格的数值是否大于一定的阈值,如果满足条件,就将该单元格的背景颜色设置为红色,如果不满足条件,就将其颜色恢复为默认颜色。
这样,当数据发生变化时,单元格的颜色也会相应地自动调整,提醒用户数据的变化。
3. 数据排序和筛选在Excel中,经常需要对大量数据进行排序和筛选,以便更好地分析和查看数据。
VBA提供了一种自动化的方式来实现数据的排序和筛选。
可以使用VBA中的Sort函数来对指定的数据区域进行排序,可以根据多个条件来排序,也可以选择升序或降序排列。
此外,可以使用VBA中的AutoFilter函数来实现数据的筛选,根据用户指定的条件来显示符合条件的数据行。
这些功能可以让用户更灵活地进行数据分析和查询,提高工作效率。
4. 数据计算和汇总VBA可以通过自动化计算和汇总数据的方式,帮助用户更快地得到结果。
可以使用VBA中的Sum函数、Average函数等来计算指定数据区域的总和、平均值等统计值。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第11章VB与Excel的数据交换Excel是目前非常流行的电子表格软件,很多人都习惯于在EXCEL中处理数据,并在Excel 中完成报表输出等功能,但Excel的数据处理功能相对较弱,而VB具有强大的数据处理功能,但报表输出功能相对较弱。
本章以实例的形式介绍VB如何从Excel中获得数据,再将处理后的数据保存到Excel工作表中,并调用Excel中的VBA指令对排版,生成数据报表。
VB中Excel的启动与关闭11.1.1 Excel对象库引用在VB中调用Excel,首先需要打开VB编程环境“工程”菜单中的“引用”项目,并选取项目中的“Microsoft Excel object library”(Excel版本不同,这个选项中的的版本号可能不一样)。
引用Excel对象库后,对编写代码会带来很多便利。
11.1.2 Excel对象声明EXCEL是以层次结构组织对象的,其对象模型中含有许多不同的对象元素。
编程过程中主要用到以下4个层次的对象。
1.Application对象,即Excel程序本身;2.WorkBook对象,即Excel的工作簿文件对象;3.WorkSheets对象,表示的是Excel的工作表对象集;例如:worksheets(1)表示第一个工作表。
4.Cells、Range、Rows、Columns对象,分别表示Excel工作表中的单元格对象集、区域对象、行对象集、列对象集。
例如:Cells(3,5) 表示第3行第5列的那个单元格Range("C5") 表示第3行第5列的那个单元格Range("A1:C5") 表示从A1单元格到C5单元格的矩形区域Rows(1) 表示第1行Range("1:1") 表示第1行Range("1:10") 表示第1到10行的区域Columns(1) 表示第1列Range("A:A") 表示第1列Range("A:D") 表示从第A到D列11.1.3 VB中Excel的启动与关闭例11-1 新建立一个VB的工程,在窗体上添加2个命令按钮(Command1和Command2),2个按钮的Caption分别为“启动Excel”和“关闭Excel”,输入以下代码即可。
Dim xls As New '声明一个Excel应用程序对象Dim xbook As New '声明一个Excel工作薄对象Dim xsheet As New '声明一个Excel工作表象Private Sub Command1_Click()Set xbook = '启动Excel,并将自动创建的工作薄赋给xbookSet xsheet = (1) '将第一个工作表赋给xsheet= True '显示Excel窗口,程序调试阶段显示该窗口非常重要End SubPrivate Sub Command2_Click()Set xls = Nothing '释放对象变量Set xbook = NothingSet xsheet = NothingEnd Sub这里将有关对象声明放在通用声明段是为了在两个命令按钮中均可以调用对象xls。
VB与Excel的数据交换当VB程序启动Excel后,就可以对其中的单元格进行任意处理了。
例11-2 随机生成的一组学生成绩数据保存到一个Excel工作表中。
新建一个VB工程,引用“Microsoft Excel object library”对象库后。
在窗体上添加2个按钮(Command1、Command2),Caption属性分别为“生成数据存入Excel”和“保存及并闭Excel”。
代码如下:Dim xls As NewDim xbook As NewDim xsheet As NewPrivate Sub Command1_Click()Set xbook =Set xsheet = (1)= True '当程序调试成功以后就可以删除此操作(1, 1) = "学号" '填写表头(1, 2) = "高等数学"(1, 3) = "英语"(1, 4) = "大学计算机基础"(1, 5) = "平均成绩"For i = 2 To 10(i, 1) = "'09108" & 1000 + I '生成学号Sum = 0For j = 2 To 4(i, j) = Int(Rnd() * 51) + 50Sum = Sum + (i, j)Next j(i, 5) = Round(Sum / 3, 2)Next iEnd SubPrivate Sub Command2_Click()("c:\") '以指定文件名存盘Set xls = Nothing '释放对象变量Set xbook = NothingSet xsheet = NothingMsgBox "请通过资源管理器查询C盘根文件夹下生成的文件"End SubVB对Excel的全面控制VB不仅可以与Excel实现数据交换,还可以对Excel进行删除或插入表行、列以及完成各种排版操作。
以下程序代码可以实现将例11-1生成的文件打开并执行各种排版操作,同例11-1一样,在窗体上添加2个命令按钮,并通过“工程”菜单“引用”Excel对象库后,录入以下代码:Dim xls As NewDim xbook As NewDim xsheet As NewPrivate Sub Command1_Click()Set xbook = "c:\") '打开Excel文件Set xsheet = (1)= True= xlMinimized '让Excel窗口最小化For i = 1 To 5With (i) '对各列样式进行设置.AutoFit '最适合列宽.HorizontalAlignment = xlCenter '水平方向居中.VerticalAlignment = xlCenter '垂直方向居中End WithNext i(1).Insert '在原表第1行前插入一行(1, 1) = "XX班级学生成绩表" '写入表标题("a1:e1").Merge '合并单元格区域("1:1").RowHeight = 40 '设置第1行行高为40磅("2:11").RowHeight = 24 '设置第2到11行行高为24磅With (1, 1) '设置表标题字体及字号. = "隶书". = 24.HorizontalAlignment = xlCenter.VerticalAlignment = xlCenterEnd WithWith Range("A2:E11") '对A2到E11区域设置表格线.Borders(xlEdgeLeft).LineStyle = xlContinuous '左边线.Borders(xlEdgeTop).LineStyle = xlContinuous '顶边线.Borders(xlEdgeBottom).LineStyle = xlContinuous '底边线.Borders(xlEdgeRight).LineStyle = xlContinuous '右边线.Borders(xlInsideVertical).LineStyle = xlContinuous '内部垂直线.Borders(xlInsideHorizontal).LineStyle = xlContinuous '内部水平线 End WithMsgBox "排版结束!"End SubPrivate Sub Command2_Click()Set xls = Nothing '释放对象变量Set xbook = NothingSet xsheet = NothingEnd SubExcel中的VBA实际上,要全面掌握EXCEL中的VBA语言是非常困难的,因为涉及到太多的对象、属性及其方法,但利用微软公司提供的宏录制功能,学习就变得易如反掌。
宏就是一段程序,存在于Office系列应用软件中,如Word、Excel、PowerPoint、Outlook 等。
对这些应用软件的所有操作步骤都可以录制成宏代码,然后再对宏代码进行分析,是学习VBA最好的方法。
下面以Excel为例,介绍宏的录制及学习方法。
如果想学习Excel中对单元格的字体、字号、边框线设置的VBA代码,操作步骤如下:(1)启动Excel,在任何一个单元格中录入一些内容,选择“工具|宏|录制新宏”,界图 11-1 录制新宏对话框面如图11-1所示。
所有内容均使用默认,单击“确定”按钮,Excel界面上会多一个宏录制工具栏,如图11-2所示。
(2)选中单元格“C4”,设置字体为“黑体”,字号为24磅,在左右加边框,完成这些操作后单击宏录制工具栏中的停止录制按钮,结束宏录制。
(3)按ALT+F11键进制Excel中的VBA集成开发环境,这个界面和VB的集成开发环境非常相似,如图11-3所示。
图 11-2 处于宏录制状态的Excel界面图 11-3 VBA集成开发环境(4)展开右侧的“模块”,可以看到其中的“模块1”,这就是刚才录制的宏,双击“模图 11-4 宏代码块1”,可以在右侧看到录制的宏代码。
如图11-4所示。
由于宏会对每一个步骤分别进行录制,所以代码看起来特别烦琐,可以将其中没有进行图 11-5 简化后的VBA代码特别处理的代码全部删除,这样就可以得到想要的VBA指令了。
如图11-5所示。
以上代码其实还可以再简化如下:Sub Macro1()= "黑体"= 24(xlEdgeLeft).LineStyle = xlContinuous(xlEdgeRight).LineStyle = xlContinuousEnd Sub这里的Selection就是指被选中的单元格或单元格区域,这些代码移植到VB中时,只需要在前面加上Selection所属的父对象名序列即可。