excel培训vba操作数据库实例

上传人:tian****1990 文档编号:73966362 上传时间:2019-01-26 格式:PPT 页数:14 大小:1.17MB
返回 下载 相关 举报
excel培训vba操作数据库实例_第1页
第1页 / 共14页
excel培训vba操作数据库实例_第2页
第2页 / 共14页
excel培训vba操作数据库实例_第3页
第3页 / 共14页
excel培训vba操作数据库实例_第4页
第4页 / 共14页
excel培训vba操作数据库实例_第5页
第5页 / 共14页
点击查看更多>>
资源描述

《excel培训vba操作数据库实例》由会员分享,可在线阅读,更多相关《excel培训vba操作数据库实例(14页珍藏版)》请在金锄头文库上搜索。

1、VBA入门范例精解,范例简介,在本次学习之前,各人要对VBA编程基础有一定程度的了解、学习。 在后面的实例中,我们将可以学习VBA程序对SQL Server数据库的简单操作,对Excel中的表格进行边框、背景颜色、文字大小、文字类型、文字格式等等一系列的设置更改。,引用类,主过程,Sub Main() unify Sheets(“X-SELL“), _ “SELECT * FROM AO_CN.hcc_risk.V_CASH_CX ORDER BY PROD_CODE“, _ “D,E,F,H,K,M,N,O,P,Q,R,S,T,U,V,W,X“, _ “L“ ThisWorkbook.Sav

2、e End Sub,注意:通常在我们编写程序时,主程序应越简单越好,这样不仅自己容易维护、应用,而且能使其它用户易读懂。,注释:在过程main()中,调用子过程unify,并向unify中传递四个参数;再调用VBA内部过程Thisworkbook.Save保存电子表格(执行完成如下:)。,Private Sub unify(ByVal sht As Worksheet, _ ByVal strSql As String, _ ByVal strPercentColumns As String, _ ByVal strDecimalColumns As String) clearSht sht

3、FillData sht, strSql lineJin sht colorSheet sht percentJin sht, strPercentColumns, “0.00%“ percentJin sht, strDecimalColumns, “0.00“ FontSheet sht, “Calibri“, 10 Columns(“A:Z“).AutoFit End Sub,整合子过程片段,注释:定义私有过程unify,并定义四个参数sht、strSql、strPercentColums、strDecimalColumns。,调用子过程clearSht、FillData、lineJin

4、、colorSheet、percentJin、percentJin、FontSheet、Columns。由于需要向子过程片段中传递一些相同的参数,并且每次都要执行些子过程,那么我们在编程时可以整合它们在一起,减少编译次数,节省执行时间。,Private Function getRowCount(ByVal sht As Worksheet) As Long Dim lRowsNum As Long Dim i As Long For i = 3 To 65535 If sht.Cells(i, 1).Value = “ Then lRowsNum = i - 1 Exit For End If

5、 Next getRowCount = lRowsNum End Function,记录表格中的数据行数,注释:这里i定义为表格的行号,列号1(A)不变,从第三行开始循环一直到65535行,如果Ai中的值为空就会跳出循环,那么行数: getRowCount=i-1,记录表格中的数据列数,Private Function getColumnCount(ByVal sht As Worksheet) As Long Dim lColumnsNum As Long Dim i As Integer For i = 1 To 255 If sht.Cells(2, i).Value = “ Then

6、lColumnsNum = i - 1 Exit For End If Next getColumnCount = lColumnsNum End Function,注释:这里i定义为表格的列号,行号2不变,从第一列开始循环一直到255列,如果i2中的值为空就会跳出循环,那么列数: getColumnCount=i-1,清除表格中记录,Private Sub clearSht(ByVal sht As Worksheet) Dim columnChr As String columnChr = Split(Cells(1, getColumnCount(sht).Address, “$“)(1

7、) Dim rowCnt As Long rowCnt = getRowCount(sht) sht.Range(“A3:“ & columnChr & rowCnt + 5).Clear End Sub,注释:调函数获取列号(由数字转换成字母) 获取行数 调用VBA内部过程 指定范围并清除数据,清除范围内的数据(包括格式、文字、字体、背景色、边框等等),Sub FillData(ByVal sht As Worksheet, _ ByVal Sql As String) Dim conn As New ADODB.Connection Dim rs As New ADODB.Recordse

8、t Dim CnStr As String CnStr = “Provider=SQLOLEDB;” _ ” _ & “Integrated Security=SSPI“ conn.Open CnStr conn.CommandTimeout = 500 rs.Open Sql, conn, 1 sht.A3.CopyFromRecordset rs rs.Close conn.Close Set conn = Nothing End Sub,操作SQL Server数据库,注释:定义过程FillData; 定义变量conn、rs、CnStr 给数据库连接串赋值 打开数据库连接 最大连接时间5

9、00s 查询并读取数据到rs 复制rs中的数据并在表sht的A3位置填充(如下图:) 关闭rs,conn 释放连接conn在内存中所占的空间,Private Sub lineJin(ByVal sht As Worksheet) 添加边框 Dim rng As Range Dim strTemp As String Dim i As Integer sht.Activate strTemp = Split(Cells(1, getColumnCount(sht).Address, “$“)(1) & getRowCount(sht) Set rng = sht.Range(“A3:“ & st

10、rTemp) rng.Select 选中需要边框的范围 For i = 7 To 12 Step 1 With Selection.Borders(i) .LineStyle = xlContinuous .ColorIndex = 0 .TintAndShade = 0 .Weight = xlThin End With Next i Set rng = Nothing End Sub,i=7添加左边框,添加边框,填充背景色,Private Sub colorSheet(ByVal sht As Worksheet) Dim columnChr As String columnChr = S

11、plit(Cells(1, getColumnCount(sht).Address, “$“)(1) Dim i As Long Dim rowCnt As Long rowCnt = getRowCount(sht) For i = 3 To rowCnt If i Mod 2 = 0 Then sht.Range(“A“ & i & “:“ & columnChr & i).Interior.Color = RGB(240, 246, 206) End If Next End Sub,注释:填充背景色。色彩由RGB红、绿、蓝三色配比而成,单色的最大值是255。在此实例中为隔行填充颜色,如下

12、:,修改字体,Private Sub FontSheet(ByVal sht As Worksheet, _ ByVal fontStyle As String, ByVal fontSize As Integer) Dim columnChr As String columnChr = Split(Cells(1, getColumnCount(sht).Address, “$“)(1) Dim rowCnt As Long rowCnt = getRowCount(sht) sht.Range(“A3:” & columnChr & rowCnt).Select 选择范围 With Sel

13、ection.Font .Name = fontStyle 字体名称(传递参数) .Size = fontSize 字体大小(传递参数) .Strikethrough = False .Superscript = False .Subscript = False .OutlineFont = False .Shadow = False .Underline = xlUnderlineStyleNone .ThemeColor = xlThemeColorLight1 .TintAndShade = 0 .ThemeFont = xlThemeFontNone End With End Sub,

14、在该实例中字体名为 Calibri,大小为10。,修改文字格式,Private Sub percentJin(ByVal sht As Worksheet, _ ByVal strColumns As String, ByVal strFormat As String) sht.Activate Dim lRowsCount As Long lRowsCount = getRowCount(sht) Dim x As Variant Dim obj As Variant x = Split(strColumns, “,“) For Each obj In x sht.Range(obj & “3:“ & obj & lRowsCount).Select sht.Range(obj & lRowsCount).Activate Selection.Style = “Percent“ 文字格式名 Selection.NumberFormat = strFormat 数字格式 Next sht.Range(obj & “2:“ & obj & 2).Select End Sub,例:E、F列格式名为percent,数字格式为0.00%,例:L列格式名为percent,数字格式为0.00,Thank You !,

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 高等教育 > 大学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号