友情提示:如果本网页打开太慢或显示不完整,请尝试鼠标右键“刷新”本网页!阅读过程发现任何错误请告诉我们,谢谢!! 报告错误
八万小说网 返回本书目录 我的书架 我的书签 TXT全本下载 进入书吧 加入书签

excel_vba_编程教程(完整版)-第64部分

按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!



   Next  
   With ActiveSheet  
        。Range(〃A2〃)pyFromRecordset rst  
        。Range(Cells(1; 1); _  
          Cells(1; rst。Fieldsunt))。Font。Bold = True  
        。Range(〃A1〃)。Select  
   End With  
   Selection。CurrentRegionlumns。AutoFit  
   rst。Close  
   Set cmd = Nothing  
   Set cat = Nothing  
 End Sub  
 想要运行上述过程的话,可以在立即窗口里面输入下述语句并回车:  
   RunAccessQuery(〃Current Product List〃)  
     
   
   
   
   

                                        302 

… 页面 319…

   
   
   
   
   
   
   
   
   
   
   
   
   
   
   
   
   
                                                       
   
 图15…11 从Excel VBA过程运行Access查询的结果被放在了一个工作表里了  
  (译者,从立即窗口运行可能遇到编译错误,如果这样的话,可以从一个子程序里调用该过程。)  

13。运行参数查询  

 你可以运行Access参数查询并将其结果放置于Excel 电子表格里面。例如,过程  
 RunAccessParamQuery通过Access数据库的参 数查询运行Employee Sales by Country,并且 
 取得7/1/96和7/30/96区间内的记录。Employee Sales by Country查询要求两个参 数:开始 
 和结束时间。      
 应该使用mand对象的Paramenters集合定义这些参数:  
 cmd。Parameters(〃'Beginning Date'〃) = StartDate  
 cmd。Parameters(〃'Ending Date'〃) = EndDate  
 设置参数后,该查询就可以使用下述语句执行了:  
 Set rst = cmd。Execute 该查询返回的记录会被赋予对象变量Recordset并使用 
 CopyFromRecordset方法复制到工作表(参见本章后面更多相关使用信 息)。  
 Sub RunAccessParamQuery()  
      ' prior to running this procedure you must set up  
      ' references to the required object libraries  
      Dim cat As ADOX。Catalog  
      Dim cmd As ADODBmand  
      Dim rst As ADODB。Recordset  
      Dim i As Integer  
      Dim dbPath As String  
      Dim StartDate As String  
      Dim EndDate As String  
      dbPath = 〃C:Program FilesMicrosoft Office” _  
        & 〃OfficeSamplesNorthwind。mdb〃  
      StartDate = 〃7/1/96〃  
      EndDate = 〃7/31/96〃  
      Set cat = New ADOX。Catalog  
      cat。ActiveConnection = 〃Provider=Microsoft。Jet。OLEDB。4。0;〃 & _  
        〃Data Source=〃 & dbPath  
      Set cmd = cat。Procedures(〃Employee Sales by Country〃)mand  
      cmd。Parameters(〃'Beginning Date'〃) = StartDate  
      cmd。Parameters(〃'Ending Date'〃) = EndDate  
      Set rst = cmd。Execute  
      Sheets(1)。Select  
            
      For i = 0 To rst。Fieldsunt … 1  
        Cells(1; i + 1)。Value = rst。Fields(i)。Name  
      Next  
        
      With ActiveSheet  
        。Range(〃A2〃)pyFromRecordset rst  

                                          303 

… 页面 320…

        。Range(Cells(1; 1); Cells(1; rst。Fieldsunt))。Font。 _  
        Bold = True  
        。Range(〃A1〃)。Select  
      End With  
      Selection。CurrentRegionlumns。AutoFit  
      rst。Close  
      Set cmd = Nothing  
      Set cat = Nothing  
 End Sub  
  (译者:本人运行上述过程不成功,将Parameters参数改为cmd。Parameters(0) = StartDate, 
 cmd。Parameters(1) = EndDate才 运行成功。另外过程给定的日期范围查询结果为空,可以更 
 改查询日期范围。译者使用示例文件Nwind。mdb。自此以下,因删除 非法软件,译者使用Excel  
 2003英文版,Access 2002英文版)  

14。调用 Access 函数   

你可以通过自动控制从Excel里直接运行Access内置函数。下面的过程调用EuroConvert函数将 
1000西班牙比赛塔转变为欧元。 EuroConvery函数使用欧盟确定的固定汇率。    
         Sub RunAccessFunction()  
           Dim objAccess As Object  
           On Error Resume Next  
            Set objAccess = GetObject(; 〃Access。Application〃)  
            'if no instance of Access is open; create a new one  
            If objAccess Is Nothing Then  
                Set objAccess = CreateObject(〃Access。Application〃)  
           End If  
           MsgBox 〃You will get 〃 & _  
              objAccess。EuroConvert(1000; 〃ESP〃; 〃EUR〃) & _  
              〃 euro dollars。 〃  
          Set objAccess = Nothing  
           End Sub  

15。获取 Access 数据到 Excel 工作表  

 有很多种方法获取外部数据到Excel。本节给你示范下述不同的技巧将Access数据导入Excel工 
 作表:  
 *   使用GetRows方法  
 *   使用CopyFromRecordset方法  
 *   使用TransferSpreadsheet方法  
 *   使用OpenDatabase方法  
 *   创建一个文本文件  
 *   创建一个查询表  

16。使用 GetRows 方法获取数据   

你可以使用GetRows方法,将Access数据放置于Excel工作表。该方法返回一个二维的数组,第一个 
下标是一个代表字段的数字, 而第二个下标则是代表记录的数字。记录和字段从0开始。 你通 
过在VBA过程里使用DAO返回数据到Excel工作表。下述示例过程示范了如何运行Northwind数据 
库里的Invoices查询,并记 录返回到Excel工作表。为了确保该过程工作正确,你必须首先建 
立对Microsoft Access 3。6 Object Library的引用。参考本章前 面的创建对对象库的引用。  
 打开Access数据库后,GetData_withDAO2过程示范使用下述语句运行Invoices查询:      
 Set qdf = db。QueryDefs(〃Invoices〃)  
 Microsoft Access 3。6 对象库里的QueryDefs对象代表一选择或者行动查询。选择查询从一 
 个或者多个表或者查询里返回数据, 然而,行动查询允许你修改数据(使用行动查询你可 
 以添加,修改或者删除记录)执行查询后,过程将查询返回的记录通过OpenRecordset方法 
 放置到对象变量Recordset上,如下所示:  
 Set rst = qdf。OpenRecordset 接下来,通过RecordCount方法获取记录数目并且放置于变 
 量countR上。注意,为了获得正确的记录数目,记录指针必须通过 使用MoveLast方法移动 
 到Recordset里的最后一条记录。  
 rst。MoveLast  
 countR = rst。RecordCount 接着,过程提示用户输入要返回到工作表的记录数目。你可以点击 
 输入对话框上的取消按钮就此取消,或者输入记录数目获取数 据。如果你输入的数字大于该 

                                          304 

… 页面 321…

 记录数目,过程将获取全部记录。在获取记录之前,你必须使用方法MoveFirst将记录指针移 
 动到 第一条记录。如果你忘了做这个,那么记录指针会停留在最后一条记录上,并且将只能 
 获取一条记录。然后,该过程继续执行, 激活Get Records工作表和清除当前范围内容。首先, 
 通过使用Recordset对象的GetRows方法,记录将返回到一个二维数组的 Variant类型变量。接 
 着,过程在数组的两维中循环将记录放置到工作表中,从单元格A2开始。这一切完成后,另一 
 个循环将在 工作表第一行里放置字段名称,并且将每列设置为自动适应列宽,以正确现实数 
 据。  
 Sub GetData_withDAO2()  
      Dim db As DAO。Database  
      Dim qdf As DAO。QueryDef  
      Dim rst As DAO。Recordset  
      Dim recArray As Variant  
      Dim i As Integer  
      Dim j As Integer  
      Dim strPath As String  
      Dim a As Variant  
      Dim countR As Long  
      Dim strShtName As String  
      strPath = 〃C:Program FilesMicrosoft Office” _  
        & 〃OfficeSamplesnorthwind。mdb〃  
      strShtName = 〃Returned records〃  
      Set db = OpenDatabase(strPath)  
      Set qdf = db。QueryDefs(〃Invoices〃)  
      Set rst = qdf。OpenRecordset  
      rst。MoveLast  
      countR = rst。RecordCount  
      a = InputBox(〃This recordset contains 〃 & _  
        countR & 〃 records。〃 & vbCrLf _  
        & 〃Enter number of records to return: 〃; _  
        〃Get Number of Records〃)  
      If a = 〃〃 Or a = 0 Then Exit Sub  
      If a 》 countR Then  
        a = countR  
        MsgBox 〃The number you entered is too large。〃 & vbCrLf _  
            & 〃All records will be returned。〃  
      End If  
      Workbooks。Add  
      ActiveWorkbook。Worksheets(1)。Name = strShtName  
      rst。MoveFirst  
      With Worksheets(strShtName)。Range(〃A1〃)  
        。CurrentRegion。Clear  
        recArray = rst。GetRows(a)  
        For i = 0 To UBound(recArray; 2)  
          For j = 0 To UBound(recArray; 1)  
               。Offset(i + 1; j) = recArray(j; i)  
          Next j  
        Next i  
        For j = 0 To rst。Fieldsunt … 1  
          。Offset(0; j) = rst。Fields(j)。Name  
          。Offset(0; j)。EntireColumn。AutoFit  
        Next j  
      End With  
      db。Close  
 End Sub  

17。使用 CopyFromRecordset 方法获取数据  

  想要将整个Recordset导入工作表的话,你可以使用Range对象的CopyFromRecordset方法。 
 该方法可以使用三个参数:Data, MaxRows和MaxColumns。只有第一个参数Data是必须的。 
 该参数可以是Recordset对象。可选参数MaxRows和MaxColumns 允许你明确应该返回的记录数 
 目(MaxRows)和字段数目(MaxColumns)。如果你忽略MaxRows参数,那么所有返回的记录 将 
 会复制到工作表;如果你忽略MaxColumns参数,那么所有的字段将会被获取。下面示范的过 
 程GetProducts使用ADO对象建  

                                         305 

… 页面 322…

 立对Northwind数据库的链接。为了让该过程工作正常,你必须先建立对Microsoft ActiveX  
 Data Objects 2。6 Library的引用(参 见本章前面有关创建对对象库引用的指导)。  
 Sub GetProducts()  
      Dim conn As New ADODBnnection  
      Dim rst As ADODB。Recordset  
      Dim strPath As String  
      strPath = 〃C:Program FilesMicrosoft Office” _  
        & 〃OfficeSamplesNorthwind。mdb〃  
      conn。Open 〃Provider=Microsoft。Jet。OLEDB。4。0;〃 _  
        & 〃Data Source=〃 & strPath & 〃;〃  
      conn。CursorLocation = adUseClient  
      ' Create a Recordset from all the records  
      ' in the Products table  
      Set rst = conn。Execute(mandText:=〃Products〃; _  
        Options:=adCmdTable)  
      ' begin with the first record rst。MoveFirst  
      ' transfer the data to Excel  
      ' get the names of fields first  
      With Worksheets(〃Sheet3〃)。Range(〃A1〃)  
        。CurrentRegion。Clear  
        For j = 0 To rst。Fieldsunt … 1  
            。Offset(0; j) = rst。Fields(j)。Name  
        Next j  
        。Offset(1; 0)pyFromRecordset rst  
        。CurrentRegionlumns。AutoFit  
      End With  
      rst。Close  
      conn。Close  
 End Sub   
 上述过程从Northwind数据库的Products表中复制所有的记录到Excel工作表。如果你想要复 
 制某一些记录的话,那么你可以使用 MaxRows参数,如下所示:  
 。Offset(1; 0)pyFromRecordset rst; 5 该语句告诉VB仅复制5条记录。 
 该Offset方法导致输入到电子表格里的记录从电子表格当前行的第二行开 
 始。 想要仅将两个表字段的所有记录发送到工作表的话,可以使用下述语 
 句:  
 。Offset(1; 0)pyFromRecordset rst; ; 2  
 该语句告诉VB从开始两列复制所有数据。在rst和数字2之间的逗号是个占位符,给被忽略的 
 MaxRows参数。   

18。使用 TransferSpreadsheet方法获取数据  

  可能使用TransferSpreadsheet方法在当前Access数据库(。mdb)或者Access项目(。adp)和 
 电子表格之间导入或者导出数据。 你也可以将Excel电子表格里的数据链接到当前Access数据 
 库。对于链接的电子表格,当Access仍然允许从Excel程序里完全访 问时,你可以使用Access 
 来查看和编辑电子表格数据。在VB里执行TransferSpreadsheet操作的TransferSpreadsheet 
 方法语法 如下:  
 DoCmd。TransferSpreadsheet 'transfertype''; spreadsheettype'; _  
       tablename; filename '; hasfieldnames''; range' 参数transfertype可以是以下常 
 数之一:acImport(缺省设置),acExport或者acLink。这些常数定义数据是否是导入,导出 
 或者 链接到数据库。  
 参数spreadsheettype可能是下述常数之一:  
 0      acSpreadsheetTypeExcel3 (default setting)  
 6           acSpreadsheetTypeExcel4  
 5           acSpreadsheetTypeExcel5  
 5           acSpreadsheetTypeExcel7  
 8           acSpreadsheetTypeExcel8  
 8           acSpreadsheetTypeExcel9  
 2           acSpreadsheetTypeLotusWK1  
 3           acSpreadsheetTypeLotusWK3  
 7           acSpreadsheetTypeLotusWK4  
 不难猜到,spreadsheettype参数明确电子表格名称和版本号。 tablename参数是个字符串表 

                                         306 

… 页面 323…

 达式,明确你想要往里面导入电子表格数据,或者从里面导出电子表格数据,或者将电子表格 
 数据 链接到的Access表的名称。除了表名称之外,你也需要明确你想要导出数据到电子表格 
 的选择查询名称。 hasfieldnames参数是个逻辑值True(…1)或者False(0)。True表明工作表第 
 一行包含字段名称;False则表示第一行包含普通数据。 缺省设置为False(第一行里没有字 
 段名称)。 参数range是个字符串表达式,明确工作表中的单元格区域或者区域名称。该参数 
 仅用于导入。如果你忽略range参数的话,那 么整个电子表格将会被导入。如果你想要导出的 
 话,就将该参数空在那里,除非你需要明确该工作表名称。 下面示范的ExportData示例程序 
 使用TransferSpreadsheet方法从Northwind数据库里的Shippers表中导出数据到 
 Shippers。xls电 子表格中。注意,该过程使用了自动控制来建立对Access的链接。建立链接后, 
 使用OpenCurrentDatabase方法打开Northwind 数据库。运行完ExportData过程后,请打开 
 C:Shippers。xls文件查看获取的数据。  
  ‘ declare at the top of the module  
 Dim objAccess As Access。Application  
 Sub ExportData()  
   Set objAccess = CreateObject(〃Access。Application〃)  
   objAccess。OpenCurrentDatabase filepath
返回目录 上一页 下一页 回到顶部 3 3
未阅读完?加入书签已便下次继续阅读!
温馨提示: 温看小说的同时发表评论,说出自己的看法和其它小伙伴们分享也不错哦!发表书评还可以获得积分和经验奖励,认真写原创书评 被采纳为精评可以获得大量金币、积分和经验奖励哦!