用VB创建复杂表格

用VB创建复杂表格

ID:38766731

大小:26.00 KB

页数:4页

时间:2019-06-19

用VB创建复杂表格_第1页
用VB创建复杂表格_第2页
用VB创建复杂表格_第3页
用VB创建复杂表格_第4页
资源描述:

《用VB创建复杂表格》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、用VB创建复杂表格 ----数据库管理系统的开发人员经常感叹的一个问题就是:我们中国人的报表太复杂了!无规则、嵌套、斜线、交叉线等历来都是困挠开发人员的最大问题。设计一个数据库固然有一定的技巧,设计数据操作也固然需要一定的逻辑分析能力,但这些问题对一般的开发人员来说应该是不成为问题的。用户可是不管你采用了多么灵活的算法多么方便的操作,他们最感兴趣的是最后他们出来的报表如何漂亮,出报表的操作如何简单(最好是一个按钮解决所有的问题)。笔者在开发数据库管理系统方面也稍有些经验,从FoxPro、Delphi、PowerBuild

2、er一直到现在用的VB,都遇到过设计打印报表的问题,这些软件在设计报表的过程中可谓各有千秋,我这里不一一细说。我在这里只向大家介绍一种我迄今为止最为满意的一种设计打印报表的方法:利用VB操作EXCEL来生成复杂的报表。----一.用VB创建外部EXCEL对象----大多数大型ActiveX-enabled应用程序和其它ActiveX部件,在它们的对象层次中都提供了一个顶层外部可创建对象。该对象提供了对该层次中其它对象的访问,并且还提供对整个应用程序起作用的方法和属性。----例如,每个MicrosoftOffice应用程

3、序提供一个顶层Application对象。下面语句显示了对MicrosoftExcel的Application对象的引用:DimxlAppAsExcel.ApplicationSetxlApp=NewExcel.Application----然后,可以用这些变量来访问在EXCEL应用程序中的从属对象、以及这些对象的属性和方法。例如:SetxlApp=CreateObject("Excel.Application")‘激活EXCEL应用程序xlApp.Visible=False‘隐藏EXCEL应用程序窗口SetxlBook

4、=xlApp.Workbooks.Open(strDestination)‘打开工作簿,strDestination为一个EXCEL报表文件SetxlSheet=xlBook.Worksheets(1)‘设定工作表----二.用EXCEL97设计报表的模版文件----EXCEL97是一个非常优秀的创建报表的工具。它提供的单元格任意合并、拆分和绘图功能基本上能够满足设计所有复杂报表的需求。它对任意一个单元格的格式随意控制,更为随心所欲地设计报表提供了强大的支持。----根据用户提供的报表,我们可以很快在EXCEL里生成模版

5、文件。所谓生成模版文件只是为了满足用户多方面的需求而设计的。也是为了适合报表以后的更改而做的一点预备工作。例如用户需要打印几百张职工履历表,但其格式都是一致的,并且随着时间和实际情况的变化,表格格式有可能需要改变,我们设计一个模版文件显然可以“以不变应万变”了。----生成工作表时我们应当记录下要填充内容的单元格编号和该单元格内要填充的数据字段。这样形成一个表格,在写程序时一目了然。如:Cell(4,2)职工姓名Cell(6,6)毕业学校Cell(4,4)职工性别Cell(6,7)所学专业Cell(4,6)职工民族Cel

6、l(6,9)工作时间(表一)----在程序里我们当然不要对模版文件进行操作了,我们只需要对模版文件的一个拷贝进行操作就行(这也是我们设计模版文件的一个目的和好处)。如下面的例子:DimstrSource,strDestinationAsStringstrSource=App.Path&"ExcelsRegisterFee.xls" ‘RegisterFee.xls就是一个模版文件strDestination=App.Path&"ExcelsTemp.xls" FileCopystrSource,strDestin

7、ation‘将模版文件拷贝到一个临时文件----三.生成工作表内容----有了上述两步工作的铺垫,我们下面接着就只要根据(表一)的格式给各单元格赋值了。如: datPrimaryRS.Recordset.MoveFirst‘datPrimaryRS为Data控件  IfIsNull(datPrimaryRS.Recordset!姓名)=FalseThen  xlSheet.Cells(4,2)=datPrimaryRS.Recordset!姓名  EndIf  IfIsNull(datPrimaryRS.Recordse

8、t!性别)=FalseThen  xlSheet.Cells(4,4)=datPrimaryRS.Recordset!性别  EndIf  IfIsNull(datPrimaryRS.Recordset!民族)=FalseThen  xlSheet.Cells(4,6)=datPrimaryRS.Recordset!

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。