VB与Excel2000实现复杂报表打印

翻译|其它|编辑:郝浩|2007-09-24 09:18:51.000|阅读 1180 次

概述:

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

数据库管理系统的开发人员经常被编制复杂的报表所困扰,VB  的水晶报表可以设计简单的报表,但是设计出的报表缺乏灵活性。我利用  VB  操作  EXCEL2000来生成复杂的报表。

  VB  创建外部  EXCEL  对象

Microsoft Office  应用程序提供了一个顶层  Application  对象。下面语句显示了对  Microsoft Excel    Application  对象的引用,用这些变量来访问在  EXCEL  应用程序中的从属对象、以及这些对象的属性和方法。:

Dim xlApp As Excel.Application
Set xlApp = New Excel.Application
Set xlApp = CreateObject("Excel.Application")
xlApp.Visible = False
Set xlBook = xlApp.Workbooks.Open(strDestination)
Set xlSheet = xlBook.Worksheets(1)

  EXCEL 2000设计报表的模版文件

EXCEL 2000是一个非常优秀的创建报表的工具。它提供的单元格任意合并、拆分功能基本上能够满足设计复杂报表的要求。它对任意一个单元格的格式随意控制,因此它为设计复杂报表提供了强大的支持。

根据用户提供的报表,我们可以很快在  EXCEL  里生成模版文件。模版文件只是为了满足用户多方面的需求而设计的。并且随着时间和实际情况的变化,表格格式有可能需要改变,我们设计一个模版文件可以以不变应万变了。在程序里我们不要对模版文件进行操作,我们只需要对模版文件的一个拷贝进行操作就行。程序代码如下:

Dim strSource, strDestination As String
strSource = App.Path & "Excelsdangan.xls"
 
strDestination = App.Path & "ExcelsTemp.xls"
 
FileCopy strSource, strDestination
Set mobjExcel = New Excel.Application
Set mobjExcel = CreateObject("Excel.Application")
mobjExcel.Visible = False
Set mobjworkbook = mobjExcel.Workbooks.Open(strDestination)
Set xlsheet = mobjworkbook.Worksheets(1)
If Not opendatasource() Then
 MsgBox "不能打开数据源!", , "提示"
 Unload Me
 Exit Sub
End If
Private Function opendatasource()
 ssql="select shgt_dah,shgt_yth,shgt_ajtm,shgt_chtrq,
 shgt_shjdw,shgt_wzysh,shgt_tzzhsh,shgt_gdrq,shgt_bz from shgtajb"
 OpenResultset ssql, mrdors
 opendatasource = True
 Exit Function
End Function

生成工作表内容

有了上述两步工作的铺垫,我们只要根据模板的格式给各单元格赋值如:

Do while Not mrdors.Eof
i=4
For j=0 to mrdors.rdocolumns.count-2
MobjExcel.Activesheet.cells(i,j+1).value=mrdors.rdocolumns(j).Value
Next
Mrdors.movenext
Loop

打印报表

生成了工作表后,就可以对  EXCEL  发出打印指令了。在执行打印操作之前应该对  EXCEL  临时文件执行一次保存操作,以免在退出应用程序后  EXCEL  还提示用户是否保存已修改的文件。如下语句:

xlBook.Save 
xlSheet.PrintOut
 
xlApp.Quit


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:百川之家

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP