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

excel_vba_编程教程(完整版)-第111章

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



mandText                                Variant SQL查询字符串。参见使用该参数的 
示例  
mandType                               Variant  查询的命令类型。可 
用的命令类型有:Deault,SQL和表 BackgroundQuery                            
Variant                                  查询的背景。可以是以下常数之 
一:PivotCache或者QueryTable ImportDataAs                                   
Variant                                  明确查询的格式。使用 
xlQueryTable报告创建一个查询表,或者  
                                         xlPivotTableReport来创建一个数据透视表  
接下来的示例过程示范了如何使用带可选参数的OpenDatabase方法。该过程从获取的客户记录 
创建了一个数据透视表。当你运 行该过程时,Excel就会基于提供的查询的字符串显示一个可 
用字段的列表。你可以拖曳一个或者多个字段到该透视表中,以创 建数据透视报告。图15…15 
显示了按国家分类的CustomerId字段。  
Sub CountCustomersByCountry()  
  Workbooks。OpenDatabase _  
     Filename:=〃C:Program FilesMicrosoft Office” _  
     & 〃Office10SamplesNorthwind。mdb〃; _  
     mandText:=〃Select * from Customers〃; _  
     BackgroundQuery:=PivotTable; _  
     ImportDataAs:=xlPivotTableReport  
End Sub  

                                       308 

… 页面 325…

  (译者:Excel 2003+Access 2002运行该过程有问题:BackgroundQuery: = PivotTable。 此 
 处有矛盾,上面的参数解释说该参 数为PivotCache或者QueryTable,而这里却是PivotTable。 
 这三个参数均导致错误。搜索对象浏览器说该参数为布尔类型。译 者将该参数改为…1,1,2, 
 10,True,False等运行,结果没有 区别。)  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
                                                                  
 图15…15 使用OpenDatabase方法的可选参数,你可以明确获取数据库数据到一个特定的格式, 
 例如数据透视报告或者查询表报告  

20。从 Access 数据创建文本文件  

  你可以使用Excel的VBA过程从Access数据创建一个以逗号或者tab分开的文本文件。文本文件 
 对于传输大量数据到电子表格特 别有用。下面的示例程序示范了如何从一个ADO recordset创 
 建一个tab分开的文本文件。为了确保该过程运行正确,你必须创建  
 对Microsoft ActiveX Data Objects 2。6 Library的引用。参考第八章中操作文本文件的详细 
 信息。运行该过程后,请在Excel  
 里打开C:ProductsOver50。txt  
 Sub CreateTextFile()  
      Dim strPath As String  
      Dim conn As New ADODBnnection  
      Dim rst As ADODB。Recordset  
      Dim strData As String  
      Dim strHeader As String  
      Dim strSQL As String  
      strPath = 〃C:Program FilesMicrosoft Office” _  
               & 〃OfficeSamplesNorthwind。mdb〃  
      conn。Open 〃Provider=Microsoft。Jet。OLEDB。4。0;〃 _  
                      & 〃Data Source=〃 & strPath & 〃;〃  
      conn。CursorLocation = adUseClient  
      strSQL = 〃SELECT * FROM Products WHERE UnitPrice 》 50〃  
      Set rst = conn。Execute(mandText:=strSQL; Options:=adCmdText)  
      'save the recordset as a tab…delimited file  
      strData = rst。GetString(StringFormat:=adClipString; _  
               ColumnDelimeter:=vbTab; _  
               RowDelimeter:=vbCr; _  
               nullExpr:=vbNullString)  
      Open 〃C:ProductsOver50。txt〃 For Output As #1  
      For Each f In rst。Fields  
               strHeader = strHeader + f。Name & vbTab  
      Next  
      Print #1; strHeader  
      Print #1; strData  
      Close #1  
 End Sub  
  (译者:如果为强制要求声明对象则还需声明变量f。) 在第八章中,你学习了如何使用 
 FileSystemObject操作文本文件。下面的过程演示了如何使用该对象来创建一个名为  

                                         309 

… 页面 326…

 ProductsOver100。txt的文本文件:  
 Sub CreateTextFile2()  
      Dim strPath As String  
      Dim conn As New ADODBnnection  
      Dim rst As ADODB。Recordset  
      Dim strData As String  
      Dim strHeader As String  
      Dim strSQL As String  
      Dim fso As Object  
      Dim myFile As Object  
      Set fso = CreateObject(〃Scripting。FileSystemObject〃)  
      Set myFile = fso。CreateTextFile(〃C:ProductsOver100。txt〃; True)  
      strPath = 〃C:Program FilesMicrosoft Office” _  
        & 〃OfficeSamplesNorthwind。mdb〃  
      conn。Open 〃Provider=Microsoft。Jet。OLEDB。4。0;〃 _  
        & 〃Data Source=〃 & strPath & 〃;〃  
      conn。CursorLocation = adUseClient  
      strSQL = 〃SELECT * FROM Products WHERE UnitPrice 》 100〃  
      Set rst = conn。Execute(mandText:=strSQL; Options:=adCmdText)  
      'save the recordset as a tab…delimited file  
      strData = rst。GetString(StringFormat:=adClipString; _  
        ColumnDelimeter:=vbTab; _  
        RowDelimeter:=vbCr; _  
        nullExpr:=vbNullString)  
      For Each f In rst。Fields  
        strHeader = strHeader + f。Name & vbTab  
      Next  
      With myFile  
        。WriteLine strHeader  
        。WriteLine strData  
        。Close  
      End With  
 End Sub  
  (译者:如果为强制要求声明对象则还需声明变量f。) 
                                                                               
 图15…16 因为文本文件可以轻易地在Excel打开,所以你可以使用它在Access和Excel之间传输 
 数据  

21。从 Access 数据创建查询表  

  如果你想要在Excel使用来自外部的数据源,而且你知道你将使用的数据会经常改变,那么你需 
 要创建一个查询表。查询表是Excel 工作表里的特殊表,它链接到外部数据源,例如Access数 
 据库,SQL服务器,网页或者文本文件。用户可以轻易地刷新查询表 来获取最更新的信息。 
 Excel提供了专门的菜单选项来获取外部数据:只要选择“数据”|“导入外部数据”,并选 
 择“新数据库 查询”。通过查询外部数据库,你可以带来一些正好适合你要求得数据。例如, 
 不必将所有的产品信息都带入你的电子表格来回 顾,你只要在获取数据之前明确数据必须达 
 到的条件就行。因此,你可以只获取单价大于20美金的产品,而不是从Access导入 所有的产 
 品。 在VBA里,你可以使用QueryTable对象访问外部数据。每个QueryTable代表从外部数据 
 源例如SQL服务器或者Access数据库创 建的工作表表格。要编程创建一个查询的话,你可以 
 使用QueryTabes集合对象的Add方法。该方法要求三个参数。本章结尾处 的示例过程使用下 
 述语句在活动工作表上创建一个查询表:  
 Set myQryTable = ActiveSheet。QueryTables。Add(strConn; Dest; strSQL) strConn是为第 
 一个参数——Connection提供数值的变量。它是必须的参数,为Variant数据类型,明确查询 
 表数据源。 Dest是为第二个参数——Destination提供数值的变量。这是个必须的参数,为 
 Range数据类型,明确在哪个单元格放置查询表。 strSQL是为第三个参数——SQL提供数值的 
 变量。这是个必须的参数,为字符串数据类型,定义要从查询返回的数据。 当你使用Add方法 
 创建查询时,该查询不会运行,直到你调用Refresh方法。该方法接受一个参数—— 
 BackgroundQuery。这是 一个Variant数据类型的可选参数,允许你决定是否在建立了对数据 
 库的链接以及查询被提交(True)后将控制返回给过程,或 者在查询已经运行并且所有数据 
 已经获取到工作表里了(False)才将控制返回给过程。 接下来的过程CreateQueryTable仅仅 
 从Northwind数据库获取产品单价大于20的Products表中的产品。注意,该过程仅在所有相 关 
 记录都被获取之后,控制才交回给过程。方法RefreshStyle决定数据如何插入工作表。下述常 

                                         310 

… 页面 327…

 数可供使用:  
 *   xlOverwriteCells  – 现存的单元格会被新数据覆盖  
 *   xlInsertDeleteCells – 插入或者删除单元格以容纳新数据  
 *   xlInsertEntireRows – 插入整行以容纳新数据  
 Sub CreateQueryTable()  
   Dim myQryTable As Object  
   Dim myDb As String  
   Di
返回目录 上一页 下一页 回到顶部 1 1
未阅读完?加入书签已便下次继续阅读!
温馨提示: 温看小说的同时发表评论,说出自己的看法和其它小伙伴们分享也不错哦!发表书评还可以获得积分和经验奖励,认真写原创书评 被采纳为精评可以获得大量金币、积分和经验奖励哦!