利用VB设计打印复杂报表[1]

[入库:2005年8月18日] [更新:2007年3月24日]

本文简介:选择自 cnviolet 的 blog

  数据库管理系统的开发人员经常感叹的一个问题就是:我们中国人的报表太复杂了!无规则、嵌套、斜线、交叉线等历来都是困挠开发人员的最大问题。设计一个数据库固然有一定的技巧,设计数据操作也固然需要一定的逻辑分析能力,但这些问题对一般的开发人员来说应该是不成为问题的。用户可是不管你采用了多么灵活的算法多么方便的操作,他们最感兴趣的是最后他们出来的报表如何漂亮,出报表的操作如何简单(最好是一个按钮解决所有的问题)。笔者在开发数据库管理系统方面也稍有些经验,从foxprodelphipowerbuilder一直到现在用的vb,都遇到过设计打印报表的问题,这些软件在设计报表的过程中可谓各有千秋,我这里不一一细说。我在这里只向大家介绍一种我迄今为止最为满意的一种设计打印报表的方法:利用vb操作excel来生成复杂的报表。

 . vb创建外部excel对象

    大多数大型 activex-enabled 应用程序和其它 activex 部件,在它们的对象层次中都提供了一个顶层外部可创建对象。该对象提供了对该层次中其它对象的访问,并且还提供对整个应用程序起作用的方法和属性。

  例如,每个 microsoft office 应用程序提供一个顶层 application 对象。下面语句显示了对microsoft excel application 对象的引用:

dim xlapp as excel.application

set xlapp = new excel.application

---- 然后,可以用这些变量来访问在excel应用程序中的从属对象、以及这些对象的属性和方法。例如:

set xlapp = createobject("excel.application")

‘激活excel应用程序

xlapp.visible = false ‘隐藏excel应用程序窗口

set xlbook = xlapp.workbooks.open(strdestination)

‘打开工作簿,strdestination为一个excel报表文件

set xlsheet = xlbook.worksheets(1)

设定工作表

---- . excel 97设计报表的模版文件

---- excel 97是一个非常优秀的创建报表的工具。它提供的单元格任意合并、拆分和绘图功能基本上能够满足设计所有复杂报表的需求。它对任意一个单元格的格式随意控制,更为随心所欲地设计报表提供了强大的支持。

---- 根据用户提供的报表,我们可以很快在excel里生成模版文件。所谓生成模版文件只是为了满足用户多方面的需求而设计的。也是为了适合报表以后的更改而做的一点预备工作。例如用户需要打印几百张职工履历表,但其格式都是一致的,并且随着时间和实际情况的变化,表格格式有可能需要改变,我们设计一个模版文件显然可以“以不变应万变”了。

---- 生成工作表时我们应当记录下要填充内容的单元格编号和该单元格内要填充的数据字段。这样形成一个表格,在写程序时一目了然。如:

cell(4,2) 职工姓名 cell(6,6) 毕业学校

cell(4,4) 职工性别 cell(6,7) 所学专业

cell(4,6) 职工民族 cell(6,9) 工作时间

(表一)

---- 在程序里我们当然不要对模版文件进行操作了,我们只需要对模版文件的一个拷贝进行操作就行(这也是我们设计模版文件的一个目的和好处)。如下面的例子:

dim strsource, strdestination as string

strsource = app.path & "\excels\registerfee.xls"

registerfee.xls就是一个模版文件

strdestination = app.path & "\excels\temp.xls"

filecopy strsource, strdestination

将模版文件拷贝到一个临时文件

---- . 生成工作表内容

---- 有了上述两步工作的铺垫,我们下面接着就只要根据(表一)的格式给各单元格赋值了。如:

本文关键:VB,打印,报表
 

本站最佳浏览方式为 分辨率 1024x768 IE 6.0(或更高版本的 IE浏览器)

go top